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. AI+IoT+电池应用

    AI+IoT+电池应用 AIoT电池 突破你的想象 将行业领先的电池电化学技术与前沿的能源物联网最佳实践相结合,利用智能物联技术开展电池全生命周期的管理优化和交叉领域的协同应用,解锁动力电池全生命周期 ...

  2. GPU端到端目标检测YOLOV3全过程(下)

    GPU端到端目标检测YOLOV3全过程(下) Ubuntu18.04系统下最新版GPU环境配置 安装显卡驱动 安装Cuda 10.0 安装cuDNN 1.安装显卡驱动 (1)这里采用的是PPA源的安装 ...

  3. 使用multus实现管理网和业务网分离——calico和flannel共存

    多个网络层面的需求 一开始为k8s集群搭建了calico网络,所有的容器都用calico对应的网卡进行通信.为了实现网络监控的清爽,想把管理组件,例如日志.统计.监控等组件挪到另外一个网络.于是产生一 ...

  4. Spring Cloud05: Zuul 服务网关

    一.什么是Zuul 服务网关 Zuul 是 Netflix 提供的⼀个开源的 API ⽹关服务器,是客户端和⽹站后端所有请求的中间层,对外开放 ⼀个 API,将所有请求导⼊统⼀的⼊⼝,屏蔽了服务端的具 ...

  5. pytest初始化与清除(一)

    一.初始化函数 1.测试用例级别:def setup() 2.套件级别(在模块文件中定义):def setup_module() 3.套件级别(在类中定义): @classmethod def set ...

  6. Jenkins 安装使用笔记

    系统要求 最低推荐配置: 256MB可用内存 1GB可用磁盘空间(作为一个容器docker运行jenkins的话推荐10GB) 为小团队推荐的硬件配置: 1GB+可用内存 50 GB+ 可用磁盘空间 ...

  7. zabbix 发现 vmvare esxi6.7 虚拟主机

    1:服务端配置确认 确保 #vi /etc/zabbiz/zabbix-server/zabbix_server.conf ## 确认其中有 StartVMwareCollectors项目 值 > ...

  8. Java编程技巧:if-else优化实践总结归纳

    文/朱季谦 说实话,其实我很讨厌在代码里大量使用if-else,一是因为该类代码属于面向过程的,二嘛,则是会显得代码过于冗余.这篇笔记,主要记录一些自己在工作实践当中针对if-else的优化心得,将会 ...

  9. Pandas高级教程之:处理text数据

    目录 简介 创建text的DF String 的方法 columns的String操作 分割和替换String String的连接 使用 .str来index extract extractall c ...

  10. external-provisioner源码分析(3)-组件启动参数分析

    更多ceph-csi其他源码分析,请查看下面这篇博文:kubernetes ceph-csi分析目录导航 external-provisioner源码分析(3)-组件启动参数分析 本文将对extern ...