Java基础00-方法引用32
1. 方法引用
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的更多相关文章
- Java基础教程——方法引用
方法引用 Lambda表达式的代码,是否可以再简洁?--方法引用 对象/类名::方法名 参数都不用写明. import java.util.function.Consumer; public clas ...
- Java基础 之软引用、弱引用、虚引用 ·[转载]
Java基础 之软引用.弱引用.虚引用 ·[转载] 2011-11-24 14:43:41 Java基础 之软引用.弱引用.虚引用 浏览(509)|评论(1) 交流分类:Java|笔记分类: Ja ...
- java基础:强引用、弱引用、软引用和虚引用 (转)
出处文章: Java基础篇 - 强引用.弱引用.软引用和虚引用 谈谈Java对象的强引用,软引用,弱引用,虚引用分别是什么 整体结构 java提供了4中引用类型,在垃圾回收的时候,都有自己的各自特点. ...
- Java基础篇 - 强引用、弱引用、软引用和虚引用
Java基础篇 - 强引用.弱引用.软引用和虚引用 原创零壹技术栈 最后发布于2018-09-09 08:58:21 阅读数 4936 收藏展开前言Java执行GC判断对象是否存活有两种方式其中一种是 ...
- 【Java 8】方法引用
一.概述 在学习lambda表达式之后,我们通常使用lambda表达式来创建匿名方法.然而,有时候我们仅仅是调用了一个已存在的方法.如下: Arrays.sort(stringsArray,(s1,s ...
- Java基础——clone()方法浅析
一.clone的概念 clone顾名思义就是复制, 在Java语言中, clone方法被对象调用,所以会复制对象.所谓的复制对象,首先要分配一个和源对象同样大小的空间,在这个空间中创建一个新的对象.那 ...
- Java基础02 方法与数据成员
作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! 在Java基础01 从HelloWorld到面向对象,我们初步了解了对象(obje ...
- java中的方法引用(method reference)官方文档总结
2017/7/5 转载写明出处:http://www.cnblogs.com/daren-lin/p/java-method-reference.html 今天要说的是java中的一项新特性,方法引用 ...
- java中的方法引用
引用静态方法:类名称::static 方法名称: 引用某个对象的方法:对象::普通方法: 引用特定类方法:特定类::方法 引用构造方法:类名称::new 范例:引用静态方法 package com.j ...
随机推荐
- GPU上稀疏矩阵的基本线性代数
GPU上稀疏矩阵的基本线性代数 cuSPARSE库为稀疏矩阵提供了GPU加速的基本线性代数子例程,这些子例程的执行速度明显快于仅CPU替代方法.提供了可用于构建GPU加速求解器的功能.cuSPARSE ...
- 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 ...
- NVIDIA深度学习Tensor Core性能解析(下)
NVIDIA深度学习Tensor Core性能解析(下) DeepBench推理测试之RNN和Sparse GEMM DeepBench的最后一项推理测试是RNN和Sparse GEMM,虽然测试中可 ...
- CPU的自动调度矩阵乘法
CPU的自动调度矩阵乘法 这是一个有关如何对CPU使用自动调度程序的文档. 与依靠手动模板定义搜索空间的基于模板的autotvm不同,自动调度程序不需要任何模板.用户只需要编写计算声明,而无需任何调度 ...
- CUDA统一内存分析
CUDA统一内存分析 PascalMIG 如 NVIDIA Titan X 和 NVIDIA Tesla P100 是第一个包含页 GPUs 定额引擎的 GPUs ,它是统一内存页错误处理和 MIG ...
- fiddler选项卡-Statistc(统计)
Statistc Statistc是fiddler用来对session列表里的Session相关情况的统计,利用这个选项,可以对请求进行性能以及其他数据分析 1.界面 2.参数详解 建议:打开fidd ...
- springboot的restful风格获取请求中携带的参数
http://localhost:8080/emp/1 有以上请求,我们controller要怎么获取请求中传递的参数1呢? 通过PathVariable注解,如下: @DeleteMapping(& ...
- Linux芯片驱动之SPI Controller
针对一款新的芯片,芯片厂商如何基于Linux编写对应的 SPI controller 驱动? 我们先看看 Linux SPI 的整体框架: 可以看到,最底层是硬件层,对应芯片内部 SPI contro ...
- huge page 能给MySQL 带来性能提升吗?
最近一直在做性能压测相关的事情,有公众号的读者朋友咨询有赞的数据库服务器有没有开启huge page,我听说过huge page会对性能有所提升,本文就一探究竟.对过程没有兴趣的可以直接看结论. 二 ...
- MySQL explain type 连接类型
查看使用的数据库版本 select version(); 5.7.30 官方提供的示例数据sakila 下载地址: https://dev.mysql.com/doc/index-other.html ...