jdk1.8中的lambda表达式学习笔记

一、引入一个例子

我们写一个多线程的例子,如下:采用实现Runable接口的方式

package cn.lyn4ever.lambda;

public class TestMain1 {
public static void main(String[] args) {
//线程1
MyThread myThread1 = new MyThread();
Thread t1 = new Thread(myThread1);
t1.start(); //线程2
MyThread myThread2 = new MyThread();
Thread t2 = new Thread(myThread2);
t2.start();
} } /**
* 我们先写一个类来实现Runable接口,为了方便直接写进了这个类中
*/
class MyThread implements Runnable { @Override
public void run() {
System.out.println("这是一个多线程:" + Thread.currentThread().getId());
}
}

当然,没有任命毛病。觉得自己写个类外部类太麻烦,那就写一个匿名内部类

package cn.lyn4ever.lambda;

public class TestMain2 {

    public static void main(String[] args) {
new Thread(new Runnable() {
@Override
public void run() {
System.out.println("这是一个线程:"+Thread.currentThread().getId());
}
}).start();
} }

这样还是不够简单,那就用lambda表达式好了.

		new Thread(()->{
System.out.println("这是一个线程:"+Thread.currentThread().getId());
}).start();

是的,就这么一句。看一个结果

二、函数式接口

所谓函数式接口,就是这个接口只有一个抽象方法,(可以包含静态方法和default方法,这是jdk1.8以后的特性),

自定义一个函数式接口的方法很简单,就是加了注解,编译器会帮我们检查代码合理性

@FunctionalInterface
public interface MyFunction { /**
* 定义一个获取字母大写的方法
* @return
*/
String getUpperCase(String letter); }

然后简单地应用下我们这个接口

 public static void main(String[] args) {
//匿名内部类
MyFunction myFunction = new MyFunction() {
@Override
public String getUpperCase(String letter) {
//实现这个方法
return letter.trim().toUpperCase();
}
};
//然后调用方法
System.out.println(myFunction.getUpperCase("this is MyFunctoinTest")); //lambda表达式
MyFunction myFunction1 = (String letter)->{
return letter.trim().toUpperCase();
}; //然后调用方法
System.out.println(myFunction1.getUpperCase("this is MyFunctoinTest"));
}

可以看到,我们定义的这个MyFunction接口并没有什么用,因为具体的实现是在匿名内部类中写的。

java.lang.Runable
java.lang.Comparable
java.lang.Comparator
java.lang.FileFilter
...

在java.util.function包中还定义了大量的功能性函数式接口,我们可以直接使用,而不用自己再去创建接口了。比如以下

1.java.util.Predicate 接收一个对象T,返回一个boolean类型结果
 //定义一个功能,如果输入0,这返回true,其他的返回false
Predicate<Integer> predicate = (Integer param) -> {
if (null != param && param == 0)
return true;
return false;
}; //直接调用predicate中的test方法
System.out.println(predicate.test(12));

可以看一个Predicate的源代码

代码的结果肯定是false,不用看了。这个接口就可以满足我们的需求,只要我们想要 接收一个对象T,返回一个boolean类型结果这样的功能,完全不用单独定义方法,只要用这个类就可以了。

还有很多,就不举例子了,将它们的功能列举出来

java.util.function.Comsumer<T> 传入对象T,只是运算,不返回结果 (大家都知道,类作为形参时是地址引入)
<R> java.util.function.Funtion<T> 传入对象T,返回对象R
<T> java.util.function.Supplier 不接收参数,提供T对象
<T> java.util.function.UnaryOperator<T> 接收参数对象T,返回结果对象T
<T> java.util.function.BinaryOperator<T,T> 接收两个T对象,返回一个T对象(下边有个例子)
public static void main(String[] args) {

        BinaryOperator<Integer> binaryOperator = (Integer i, Integer j) -> {
//返回两个数中较大的一个
return i > j ? i : j;
}; System.out.println(binaryOperator.apply(12,13));//13
}

三、Lambda表达式的基本语法

1.基本语法

  • 0.基本语法:

    T r = new T { () -> {这里边是方法的具体实现} };
  • 1.lambda表达式要和接口绑定,
  • 2.如果表达式中方法的实现只有一条语句,可以不写{} 和 reutrn 关键字,否则必须要写(如果有返回值就要写reutrn,没有不用写)
  • 3.如果接口中的方法有参数,在() 中参数的类型,可写可不写

看一个例子

package cn.lyn4ever.lambda.exmple;

public class ExampleDemo {
public static void main(String[] args) { NoResultNoParam noResultNoParam = () -> System.out.println("NoResultNoParam");
noResultNoParam.test(); NoResultHasParam noResultHasParam = (param) -> System.out.println(param);
noResultHasParam.test("hello"); HasResultHasParam hasResultHasParam = (x, y) -> {
int z = x + y;
return z;
};
//下边这个也可以,只有一个返回值时,不用写{}
HasResultHasParam hasResultHasParam1 = (x, y) -> x + y;
System.out.println(hasResultHasParam.test(1,2));
System.out.println(hasResultHasParam1.test(10,20)); } } interface NoResultNoParam {
void test();
} interface NoResultHasParam {
void test(String param);
} interface HasResultHasParam {
int test(int x, int y);
}

本文代码已上传至github,觉得好的话,给个star

Lambda入门,看这一篇幅就够了的更多相关文章

  1. Vue开发入门看这篇文章就够了

    摘要: 很多值得了解的细节. 原文:Vue开发看这篇文章就够了 作者:Random Fundebug经授权转载,版权归原作者所有. 介绍 Vue 中文网 Vue github Vue.js 是一套构建 ...

  2. Mybatis入门看这一篇就够了

    什么是MyBatis MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名为 ...

  3. Spring入门看这一篇就够了

    前言 前面已经学习了Struts2和Hibernate框架了.接下来学习的是Spring框架...本博文主要是引入Spring框架... Spring介绍 Spring诞生: 创建Spring的目的就 ...

  4. Git入门看这一篇就够了! (转)

    Git 的三种状态 Git 有三种状态,你的文件可能处于其中之一: 已提交(committed):数据已经安全的保存在本地数据库中. 已修改(modified):已修改表示修改了文件,但还没保存到数据 ...

  5. JSON入门看这一篇就够了

    什么是JSON JSON:JavaScript Object Notation [JavaScript 对象表示法] JSON 是存储和交换文本信息的语法.类似 XML. JSON采用完全独立于任何程 ...

  6. Python + Appium 自动化操作微信入门看这一篇就够了

    简介 Appium 是一个开源的自动化测试工具,支持 Android.iOS 平台上的原生应用,支持 Java.Python.PHP 等多种语言. Appium 封装了 Selenium,能够为用户提 ...

  7. RabbitMQ入门看这一篇就够了

    一文搞懂 RabbitMQ 的重要概念以及安装 一 RabbitMQ 介绍 这部分参考了 <RabbitMQ实战指南>这本书的第 1 章和第 2 章. 1.1 RabbitMQ 简介 Ra ...

  8. Spring Cloud入门看这一篇就够了

    目录 SpringCloud微服务 架构演进 服务调用方式: Euraka服务注册中心 注册中心 服务提供者(服务注册) 服务消费者(服务发现) 服务续约 失效剔除和自我保护 Consul 特性 Co ...

  9. MySQL入门看这一篇就够了

    MySQL JavaEE:企业级Java开发 web阶段 分为1.前端(页面,展示数据库中的数据) 2.后台(连接点:链接数据库JDBC.Mybatis,链接前端(控制视图跳转,给前端传递数据)) 3 ...

随机推荐

  1. 设计模式C++描述----13.代理(Proxy)模式

    一. 举例说明 我们有时打开一个网站时会发现有这样的现象,网站上的文字都显示出来了,但是上面的图片还没显示,要等一会才能显示. 这些未打开的图片的位置上,还是会有图片框和一些等待的信息的,这就是代理模 ...

  2. sql中实现先排序后分组

    数据表结构和数据如下: CREATE TABLE `commun_message_chat_single` ( `id` ) NOT NULL AUTO_INCREMENT, `chat_id` ) ...

  3. NLP预训练模型-百度ERNIE2.0的效果到底有多好【附用户点评】

    ERNIE是百度自研的持续学习语义理解框架,该框架支持增量引入词汇(lexical).语法 (syntactic) .语义(semantic)等3个层次的自定义预训练任务,能够全面捕捉训练语料中的词法 ...

  4. NOI导刊总结

    NOI导刊总结 前两天去郑州,参加了什么NOI导刊的培训,然后就发现大佬是真的多,还十分意外的发现了一个事,清华北大是不是发笔记本和耳机,为啥三个老师的都一模一样... 这几天主要以讲.NOIP知识点 ...

  5. MATLAB基本使用及SIMULINK建模仿真实验

    MATLAB基本使用及SIMULINK建模仿真实验 这是我总结的操作方法: 1 )  M脚本文件的编写 1.新建M-file: 2.输入指令: 3.保存(注意:保存路径需要与工作路径一致) 2 )在S ...

  6. PowerMock学习(一)之PoweMock的入门--模拟新增学生操作

    关于powermock 在TDD领域Mock框架有很多,比如EasyMock,JMock,Mockito.可能有些同学会好奇了,为什么要重点把powermock拿出来呢,因为powermock可以解决 ...

  7. 深入理解计算机系统 第三章 程序的机器级表示 part1

    如题所示,这一章讲解了程序在机器中是怎样表示的,主要讲汇编语言与机器语言. 学习什么,为什么学,以及学了之后有什么用 我们不用学习如何创建机器级的代码,但是我们要能够阅读和理解机器级的代码. 虽然现代 ...

  8. C++对象模型结论

    C++对象模型 1.C++对象模型探讨的是对象成员存储问题. 2.结论: (1) .类内部的函数(静态成员函数,非静态成员函数)都不在对象内部 ,不占用对象大小. (2) 类内部的静态变量不占用对象大 ...

  9. python的模块future用法实例解析

    计算机的知识太多了,很多东西就是一个使用过程中详细积累的过程.最近遇到了一个很久关于future的问题,踩了坑,这里就做个笔记,免得后续再犯类似错误.   future的作用:把下一个新版本的特性导入 ...

  10. nyoj 17-单调递增最长子序列 && poj 2533(动态规划,演算法)

    17-单调递增最长子序列 内存限制:64MB 时间限制:3000ms Special Judge: No accepted:21 submit:49 题目描述: 求一个字符串的最长递增子序列的长度 如 ...