1. 方法引用

Java8新特征之方法引用

1.1 体验方法引用

  
代码示例:

需求:

  • 1:定义一个接口(Printable):里面定义一个抽象方法: void printString(String s);
  • 2:定义一个测试类(PrintableDemo),在测试类中提供两个方法

  一个方法是: usePrintable(Printable p)
  一个方法是主方法,在主方法中调用usePrintable方法
接口:

//1:定义一个接口(Printable):里面定义一个抽象方法: void printString(String s);
public interface Printable {
void printString(String s);
}

测试类:

//2:定义一个测试类(PrintableDemo),在测试类中提供两个方法
//一个方法是: usePrintable(Printable p)
//一个方法是主方法,在主方法中调用usePrintable方法
public class PrintableDemo {
public static void main(String[] args) {
//Lambda表达式省略参数类型,是因为方法中有参数类型这样Lambda就可以推导出参数类型。
usePrintable(s -> System.out.println(s)); // 使用方法一引用,方法引用符::
//方法引用和Lambda一样都是推导出了参数类型,然后将参数放入println中。
usePrintable(System.out::println);
} private static void usePrintable(Printable p) {
p.printString("爱生活爱java");
}
}

运行结果:

  

1.2 方法引用符

  
代码示例:
需求:

  • 1:定义一个接口(Printable):里面定义一个抽象方法: void printInt(int i);
  • 2:定义一一个测试类(PrintableDemo),在测试类中提供两个方法

  一个方法是: usePrintable(Printable p)
  一个方法是主方法,在主方法中调用usePrintable方法
定义接口:

//1:定义一个接口(Printable):里面定义一个抽象方法: void printInt(int i);
public interface Printable {
void printInt(int i);
}

定义测试类:

//2:定义一一个测试类(PrintableDemo),在测试类中提供两个方法
//一个方法是: usePrintable(Printable p)
//一个方法是主方法,在主方法中调用usePrintable方法
public class PrintableDemo {
private static void usePrintable(Printable p) {
p.printInt(666);
} public static void main(String[] args) {
//Lambda表达式
usePrintable(i -> System.out.println(i)); //方法引用
usePrintable(System.out::println);
}
}

运行结果:

  

1.3 Lambda表达式支持的方法引用

  

1.4 引用类方法

  

代码示例:

定义接口:

//1:定义一个接口(Converter),里面定义一个抽象方法:
//int convert(String s);
public interface Converter {
int convert(String s);
}

定义测试类:

//2:定义一一个测试类(ConverterDemo),在测试类中提供两个方法
//一个方法是: useConverter(Converter c)
//一个方法是主方法,在主方法中调用useConverter方法
public class ConverterDemo {
private static void useConverter(Converter c) {
int number = c.convert("666");
System.out.println(number);
} public static void main(String[] args) {
// Lambda表达式
// 带有返回值类型的也可以省略
useConverter(s -> Integer.parseInt(s)); // 引用类方法,采用引用类方法格式
useConverter(Integer::parseInt); // Lambda表达式被类方法替代的时候,它的形式参数全部传递给静态方法作为参数 }
}

运行结果:

  

1.5 引用对象的实例方法

  
代码示例:

定义类:

//1:定义一个类(PrintString),里面定义一个方法
// public void printUpper(String s): 把字符串参数变成大写的数据,然后在控制台输出
public class PrintString {
public void printUpper(String s) {
String result = s.toUpperCase();
System.out.println(result);
}
}

定义接口:

//2:定义一个接口(Printer),里面定义一个抽象方法
//void printUpperCase(String s);
public interface Printer {
void printUpperCase(String s);
}

定义测试类:

//3:定义一个测试类(PrinterDemo),在测试类中提供两个方法
//一个方法是: usePrinter(Printer p)
//一个方法是主方法,在主方法中调用usePrinter方法
public class PrinterDemo {
private static void usePrinter(Printer p) {
p.printUpperCase("HelloWordl");
} public static void main(String[] args) {
// Lambda表达式,最简化模式
usePrinter(s -> System.out.println(s.toUpperCase())); // 引用对象的是实例方法
PrintString ps = new PrintString();
usePrinter(ps::printUpper); // Lambda表达式被对象的实例方法替代的时候,它的形式参数全部传递给该方法作为参数
}
}

运行结果:

  

1.6 引用类的实例方法

  
代码示例:

定义接口:

//1:定义一个接口(MyString),里面定义一个抽象方法: .
//String mySubString(String s,int x, int y);
public interface MyString {
String mySubString(String s, int x, int y);
}

定义测试类:

//2:定义一个测试类(MyStringDemo),在测试类中提供两个方法
//一个方法是: useMyString(MyString my)
//一个方法是主方法,在主方法中调用useMyString方法
public class MyStringDemo {
private static void useMyString(MyString my) {
String s = my.mySubString("HelloWorld", 2, 5);
System.out.println(s);
} public static void main(String[] args) {
// Lambda表达式,最简模式
useMyString((s, x, y) -> s.substring(x, y)); // 引用类的实例方法
useMyString(String::substring); // Lambda表达式被类的实例方法替代的时候
// 第一个参数作为调用者
// 后面的参数全部传递给该方法作为参数
}
}

运行结果:

  

1.7 引用构造器(构造方法)

  
代码示例:

定义类Student

//1:定义一个类(Student),里面有两个成员变量(name, age)
//并提供无参构造方法和带参构造方法,以及成员变量对应的get和set方法
public class Student {
private String name;
private int age; public Student() {
super();
} public Student(String name, int age) {
super();
this.name = name;
this.age = age;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public int getAge() {
return age;
} public void setAge(int age) {
this.age = age;
}
}

定义接口:

//2:定义一个接口(StudentBuilder),里面定义一个抽象方法
//Student build(String name, int age);
public interface StudentBuilder {
Student build(String name, int age);
}

定义测试类:

//3:定义一个测试类(StudentDemo),在测试类中提供两个方法
//一个方法是: useStudentBuilder(StudentBuilder s)
//一个方法是主方法,在主方法中调用useStudentBuilder方法
public class StudentDemo { private static void useStudentBuilder(StudentBuilder sb) {
Student s = sb.build("林青霞", 20);
System.out.println(s.getName() + "," + s.getAge());
} public static void main(String[] args) {
// Lambda表达式
useStudentBuilder((name, age) -> new Student(name, age)); // 引用构造器
useStudentBuilder(Student::new); // Lambda表达式被构造器替代的时候,它的形式参数全部传递给构造器作为参数
}
}

运行结果:

  

Java基础00-方法引用32的更多相关文章

  1. Java基础教程——方法引用

    方法引用 Lambda表达式的代码,是否可以再简洁?--方法引用 对象/类名::方法名 参数都不用写明. import java.util.function.Consumer; public clas ...

  2. Java基础 之软引用、弱引用、虚引用 ·[转载]

    Java基础 之软引用.弱引用.虚引用 ·[转载] 2011-11-24 14:43:41 Java基础 之软引用.弱引用.虚引用 浏览(509)|评论(1)   交流分类:Java|笔记分类: Ja ...

  3. java基础:强引用、弱引用、软引用和虚引用 (转)

    出处文章: Java基础篇 - 强引用.弱引用.软引用和虚引用 谈谈Java对象的强引用,软引用,弱引用,虚引用分别是什么 整体结构 java提供了4中引用类型,在垃圾回收的时候,都有自己的各自特点. ...

  4. Java基础篇 - 强引用、弱引用、软引用和虚引用

    Java基础篇 - 强引用.弱引用.软引用和虚引用 原创零壹技术栈 最后发布于2018-09-09 08:58:21 阅读数 4936 收藏展开前言Java执行GC判断对象是否存活有两种方式其中一种是 ...

  5. 【Java 8】方法引用

    一.概述 在学习lambda表达式之后,我们通常使用lambda表达式来创建匿名方法.然而,有时候我们仅仅是调用了一个已存在的方法.如下: Arrays.sort(stringsArray,(s1,s ...

  6. Java基础——clone()方法浅析

    一.clone的概念 clone顾名思义就是复制, 在Java语言中, clone方法被对象调用,所以会复制对象.所谓的复制对象,首先要分配一个和源对象同样大小的空间,在这个空间中创建一个新的对象.那 ...

  7. Java基础02 方法与数据成员

    作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! 在Java基础01 从HelloWorld到面向对象,我们初步了解了对象(obje ...

  8. java中的方法引用(method reference)官方文档总结

    2017/7/5 转载写明出处:http://www.cnblogs.com/daren-lin/p/java-method-reference.html 今天要说的是java中的一项新特性,方法引用 ...

  9. java中的方法引用

    引用静态方法:类名称::static 方法名称: 引用某个对象的方法:对象::普通方法: 引用特定类方法:特定类::方法 引用构造方法:类名称::new 范例:引用静态方法 package com.j ...

随机推荐

  1. GPU上稀疏矩阵的基本线性代数

    GPU上稀疏矩阵的基本线性代数 cuSPARSE库为稀疏矩阵提供了GPU加速的基本线性代数子例程,这些子例程的执行速度明显快于仅CPU替代方法.提供了可用于构建GPU加速求解器的功能.cuSPARSE ...

  2. YOLOvi(i=1,2,3,4)系列

    YOLOvi(i=1,2,3,4)系列 YOLOv4论文链接:https://arxiv.org/pdf/2004.10934.pdf YOLOv4源码链接:https://github.com/Al ...

  3. NVIDIA深度学习Tensor Core性能解析(下)

    NVIDIA深度学习Tensor Core性能解析(下) DeepBench推理测试之RNN和Sparse GEMM DeepBench的最后一项推理测试是RNN和Sparse GEMM,虽然测试中可 ...

  4. CPU的自动调度矩阵乘法

    CPU的自动调度矩阵乘法 这是一个有关如何对CPU使用自动调度程序的文档. 与依靠手动模板定义搜索空间的基于模板的autotvm不同,自动调度程序不需要任何模板.用户只需要编写计算声明,而无需任何调度 ...

  5. CUDA统一内存分析

    CUDA统一内存分析 PascalMIG 如 NVIDIA Titan X 和 NVIDIA Tesla P100 是第一个包含页 GPUs 定额引擎的 GPUs ,它是统一内存页错误处理和 MIG ...

  6. fiddler选项卡-Statistc(统计)

    Statistc Statistc是fiddler用来对session列表里的Session相关情况的统计,利用这个选项,可以对请求进行性能以及其他数据分析 1.界面 2.参数详解 建议:打开fidd ...

  7. springboot的restful风格获取请求中携带的参数

    http://localhost:8080/emp/1 有以上请求,我们controller要怎么获取请求中传递的参数1呢? 通过PathVariable注解,如下: @DeleteMapping(& ...

  8. Linux芯片驱动之SPI Controller

    针对一款新的芯片,芯片厂商如何基于Linux编写对应的 SPI controller 驱动? 我们先看看 Linux SPI 的整体框架: 可以看到,最底层是硬件层,对应芯片内部 SPI contro ...

  9. huge page 能给MySQL 带来性能提升吗?

    最近一直在做性能压测相关的事情,有公众号的读者朋友咨询有赞的数据库服务器有没有开启huge page,我听说过huge page会对性能有所提升,本文就一探究竟.对过程没有兴趣的可以直接看结论. 二 ...

  10. MySQL explain type 连接类型

    查看使用的数据库版本 select version(); 5.7.30 官方提供的示例数据sakila 下载地址: https://dev.mysql.com/doc/index-other.html ...