public class Test05 {
/*
* lambda表达式是用来简化匿名内部类的一种函数式编程的语法。
* 只有SAM接口才能使用lambda表达式
* 方法引用和构造器引用是用来简化lambda表达式。
* 只有当lambda表达式满足一些特殊情况时,才能使用方法引用和构造器引用。
*
* 条件:
* (1)当Lambda体的实现是通过调用一个现有的方法来完成功能时
* (2)要求函数式接口的抽象方法返回值类型与该方法的返回值类型要对应。
* (3)要求函数式接口的抽象方法的形参列表与该方法的形参列表对应
* 或者
* 要求函数式接口的抽象方法的形参列表的第一个形参是作为调用方法的对象,剩余的形参正好是给这个方法的实参列表
*
* 方法引用的语法格式:
* (1)对象::实例方法名
* (2)类名::静态方法名
* (3)类名::实例方法名
*
* 条件:
* (1)当Lambda体的实现是通过创建一个对象来实现的
* (2)要求函数式接口的抽象方法返回值类型与该对象的类型一致
* (3)要求函数式接口的抽象方法的形参列表与该对象创建时的构造器的形参列表对应
*
* 构造器引用语法格式:
* (1)类名::new
* (2)数组类型::new
*/
public static void main(String[] args) {
// test01();
// test02();
// test03();
// test04();
//     test05();
      test06();

} public static void test01() {
List<Integer> list = Arrays.asList(1, 2, 3, 4, 5); /*
* default void forEach(Consumer<? super T> action)
* 形参的类型是Consumer接口,可以使用Lambda表达式赋值
* Consumer<T> void accept(T t)
*
*/ //list.forEach(num -> System.out.println(num));
//以前我的输出是带有箭头的,但是换成方法引用后可以更加的简便
/*
* (1)这里的lambda表达式是通过调用一个现有的方法来完成的,是out对象的println()方法来完成
* (2)Consumer<T> public void accept(T t)
* PrintStream类的out对象 public void println(Object x)
*/
//对象::实例方法名
list.forEach(System.out::println);
}
public static void test02() {
/*
* Stream的
* public static<T> Stream<T> generate(Supplier<T> s)
* 形参是Supplier接口类型,赋值为Lambda表达式
*
* (1)抽象方法 T get()
* (2)如何实现, 用Math.random()随机产生一个[0,1)范围的数
*/
// Stream<Double> stream = Stream.generate(() -> Math.random()); /*
* Supplier接口的抽象方法 T get() Double get()
* 调用的是 double Math.random()
*/
//使用方法引用 类名::静态方法名
Stream<Double> stream = Stream.generate(Math::random);
stream.forEach(System.out::println);
} public static void test03(){
String[] arr = {"bmw","Mercedes-benz","audi","Porsche","Ferrari"}; //不区分大小写的排序
/*
* public static <T> void sort(T[] a, Comparator<? super T> c)
* 第二个形参:Comparator接口,SAM接口,赋值为Lambda表达式
*
* Comparator<String>接口的抽象方法:
* int compare(String s1, String s2)
* 如何实现?不区分大小写比较字符串
*/
// Arrays.sort(arr);
//排序结果[Ferrari, Mercedes-benz, Porsche, audi, bmw] // Arrays.sort(arr, (s1,s2) -> s1.compareToIgnoreCase(s2));
//排序结果[audi, bmw, Ferrari, Mercedes-benz, Porsche]
/*
* Comparator<String>接口 int compare(String s1, String s2)
* String类的 int compareToIgnoreCase(String str) 此处,s1正好是调用compareToIgnoreCase的对象,s2是给它的参数
*/
//使用方法引用优化
Arrays.sort(arr, String::compareToIgnoreCase);
//排序结果[audi, bmw, Ferrari, Mercedes-benz, Porsche]
System.out.println(Arrays.toString(arr));
}
public static void test04(){
//lambda表达式也可以用于给SAM接口的变量赋值
/*
* Supplier<T> 接口的抽象方法 T get()
* 如何实现这个抽象方法,例如:这里要new一个String的空对象
*/
// Supplier<String> s = () -> new String(); //就可以使用构造器引用,来创建对象
Supplier<String> s = String::new;
} public void test05(){
//调用createArray这个方法,创建一个2的n次方长度的数组
/*
* public <R> R[] createArray(Function<Integer,R[]> fun,int length)
* 第一个参数:Function<Integer,R[]>接口 ,是SAM接口,可以赋值为Lambda表达式
* Function<T,R>接口的抽象方法: R apply(T t)
*
* R[] apply(Integer i)
* 如何实现,创建一个长度为i的R类型的数组
*
*/
// String[] arr = createArray((Integer i) -> new String[i], 10);
//优化为 String[] arr = createArray(String[]::new, 10);
System.out.println(Arrays.toString(arr));
System.out.println(arr.length);
} /*
* 模仿HashMap的源码实现的一个方法,功能是,可以创建一个2的n次方长度的数组
* 例如:这个length是你希望的数组的长度,但是它可能不是2的n次方,那么我会对length进行处理,纠正为一个2的n次方长度,并且创建这个数组
*/
public <R> R[] createArray(Function<Integer,R[]> fun, int length){
int n = length - 1;
n |= n >>> 1;
n |= n >>> 2;
n |= n >>> 4;
n |= n >>> 8;
n |= n >>> 16;
length = n < 0 ? 1 : n + 1;
return fun.apply(length);
} public void test06(){
new Thread(() -> System.out.println("hello")).start();//不能使用方法引用来优化
}
}

Lombda表达式(五)的更多相关文章

  1. Lombda表达式(四)

    /* * 自定义函数式接口: * 1.声明一个接口,只能包含一个抽象方法 * 2.给这个接口加@FunctionalInterface */ public class Test { public st ...

  2. Python函数式编程之lambda表达式

    一:匿名函数的定义 lambda parameter_list: expression 二:三元表达式 条件为真时返回的结果 if 条件判断 else 条件为假的时候返回的结果 三:map map(f ...

  3. 微软BI 系列随笔列表 (SSIS, SSRS, SSAS, MDX, SQL Server)

    [公告]本博客于2015年10月起不再更新 新博客文章主要发表在商业智能BI社区: http://www.flybi.net/blog/biwork 博客地图自动分类 文章目录方便更好的导航,阅读文章 ...

  4. 嵌入式Linux应用开发——Linux下的C编程基础

    一.markdown简单操作 1.标题 在文字开头加上 “#”,通过“#”数量表示几级标题. 通过在文字下方添加“=”和“-”,他们分别表示一级标题和二级标题. 2.块注释 通过在文字开头添加“> ...

  5. ASP.NET验证控件应用实例与详解。

    ASP.NET公有六种验证控件,分别如下:  控件名      功能描叙 1RequiredFieldValidator(必须字段验证)  用于检查是否有输入值 2CompareValidator(比 ...

  6. C语言控制语句总结(if else for switch while break continue)

    一.if语句 1表达式 if(条件表达式) 语句 注: (1)条件表达式,一般为逻辑表达式或关系表达式,但也可以是任何数值类型,如整型.实型.字符型.指针型数据等. (2)语句,由于是C语言的语句,而 ...

  7. webform 验证控件

    验证: 一.非空验证  RequiredFieldValidator ErrorMessage - 验证出错后的提示信息 ControlToValidate - 要验证的控件的ID Display - ...

  8. Python学习之路——函数

    一.Python2.X内置函数表: 注:以上为pyton2.X内置函数,官方网址:https://docs.python.org/2/library/functions.html 二.Python3. ...

  9. 网站教学 提纲总结到ajax结束后面还有

    Repeater - 重复器五个模板:HeaderTemplate - 在最上面,显示一次FooterTemplate - 最下面,显示一次ItemTemplate - 在中间,显示n次Alterna ...

随机推荐

  1. volatile域浅析

    内存模型的相关概念 计算机中执行程序时,每条指令都是在CPU中执行,执行指令的过程必然会涉及到数据的读取和写入.而程序运行时的数据是存放在主存(物理内存)中,由于CPU的读写速度远远高于内存的速度,如 ...

  2. 一个提高N倍系统新能的编程点,却总是被普通开发们遗忘

    位运算这个概念并不陌生,大多数程序员在进入这个领域的时候或多或少都接触过位运算,估计当时都写过不少练习题的. 位运算本身不难,困难的是大家没有学会在系统设计时用上它,提高系统性能,增加你的不可替代性. ...

  3. session深入探讨

    简介 session(会话),其实是一个容易让人误解的词.它总跟web系统的会话挂钩,利用session,javaweb项目实现了登录状态的控制.坊间流传,关闭浏览器,就是关闭了web系统的会话. 其 ...

  4. kali一些基础工具

    目录 netcat netcat https://blog.csdn.net/fageweiketang/article/details/82833193 网络工具当中的瑞士军刀 -nc指令,nc可以 ...

  5. 解决npm被墙的问题

    npm存储包文件的服务器在国外,有时候会被墙,速度很慢,所以我们需要解决这个问题. http://npm.taobao.org/  淘宝的开发团队把npm在国内做了一个备份. 安装淘宝的cnpm np ...

  6. 利用 esp8266 搭建简单物联网项目

    接上一篇博客,这次还是关于 esp8266 --> 物联网 一.云端数据监控:DHT11 + NodeMcu +Dweet.io 接上一篇博客的接线及相关配置不变( DHT11 + NodeMc ...

  7. is_mobile()判断手机移动设备

    is_mobile()判断手机移动设备.md is_mobile()判断手机移动设备 制作响应式主题时会根据不同的设备推送不同的内容,是基于移动设备网络带宽压力,避免全局接收pc端内容. functi ...

  8. ZooKeeper-3.5.6分布式锁

    原理 基本方案是基于ZooKeeper的临时节点与和watch机制.当要获取锁时在某个目录下创建一个临时节点,创建成功则表示获取锁成功,创建失败则表示获取锁失败,此时watch该临时节点,当该临时节点 ...

  9. 设备通讯——RS232

    RS232的接口有两种--一种公头.一种母头,两种头的引脚是有区别的 MAX232电路图: 注意:串口通讯需要交叉接线.

  10. Solon集成(02)- 轻松吃下小馒头 Dubbo

    Solon详解系列文章: Solon详解(一)- 快速入门 Solon详解(二)- Solon的核心 Solon详解(三)- Solon的web开发 Solon详解(四)- Solon的事务传播机制 ...