技术标签: java8 lambda 视频
Lambda表达式介绍
Java 8的一个大亮点是引入Lambda表达式,使用它设计的代码会更加简洁。通过Lambda表达式,可以替代我们以前经常写的匿名内部类来实现接口。Lambda表达式本质是一个匿名函数;
体验Lambda表达式
我们通过一个小例子来体验下Lambda表达式;
我们定义一个计算接口 只有一个方法add;
public classProgram {public static voidmain(String[] args) {
Cal c1=newCal() {
@Overridepublic int add(int a, intb) {return a+b;
}
};int c=c1.add(1,2);
System.out.println(c);
}
}interfaceCal{int add(int a,intb);
}
这个是我们以前的实现,匿名内部类,然后调用执行;
我们现在用Lambda表达式改写下:
public classProgram {public static voidmain(String[] args) {
Cal c1=(int a,int b) ->{return a+b;};int c=c1.add(1,2);
System.out.println(c);
}int add(int a,intb){return a+b;
}
}interfaceCal{int add(int a,intb);
}
匿名内部类,直接改成了:
Cal c1=(int a,int b) ->{return a+b;};
简洁多了;
是不是感觉Lambda表达式挺强大,
接下来我们来看看Lambda表达式的语法吧;
Lambda表达式语法
我们看下这个Lambda表达式:
(int a,int b) ->{return a+b;};
这个本质是一个函数;
一般的函数类似如下:
int add(int a,intb){return a+b;
}
有返回值,方法名,参数列表,方法体
Lambda表达式函数的话,只有参数列表,和方法体;
( 参数列表 ) -> { 方法体 }
说明:
( ) :用来描述参数列表;
{ } : 用来描述方法体;
-> :Lambda运算符,可以叫做箭头符号,或者goes to
Lambda表达式语法细讲
我们搞一个案例,接口方法参数,无参,单个参数,两个参数,有返回值,没有返回值,这六种情况都罗列下:
interfaceIf1{/**
* 无参数无返回值*/
voidtest();
}interfaceIf2{/**
* 单个参数无返回值
* @param a*/
void test(inta);
}interfaceIf3{/**
* 两个参数无返回值
* @param a
* @param b*/
void test(int a,intb);
}interfaceIf4{/**
* 无参数有返回值
* @return*/
inttest();
}interfaceIf5{/**
* 单个参数有返回值
* @param a
* @return*/
int test(inta);
}interfaceIf6{/**
* 多个参数有返回值
* @param a
* @param b
* @return*/
int test(int a,intb);
}
我们用Lambda表达式实现:
//无参数无返回值
If1 if1=()->{
System.out.println("无参数无返回值");
};
if1.test();//单个参数无返回值
If2 if2=(int a)->{
System.out.println("单个参数无返回值 a="+a);
};
if2.test(3);//两个参数无返回值
If3 if3=(int a,int b)->{
System.out.println("两个参数无返回值 a+b="+(a+b));
};
if3.test(2,3);//无参数有返回值
If4 if4=()->{
System.out.print("无参数有返回值");return 100;
};
System.out.println(if4.test());//单个参数有返回值
If5 if5=(int a)->{
System.out.print("单个参数有返回值");returna;
};
System.out.println(if5.test(200));//多个参数有返回值
If6 if6=(int a,int b)->{
System.out.print("多个参数有返回值");return a+b;
};
System.out.println(if6.test(1,2));
运行输出:
无参数无返回值
单个参数无返回值 a=3两个参数无返回值 a+b=5无参数有返回值100单个参数有返回值200多个参数有返回值3
Lambda表达式精简语法
那件语法注意点:
参数类型可以省略
假如只有一个参数,()括号可以省略
如果方法体只有一条语句,{}大括号可以省略
如果方法体中唯一的语句是return返回语句,那省略大括号的同事return也要省略
改写实例:
/**
* @author java1234_小锋
* @site www.java1234.com
* @company Java知识分享网
* @create 2020-08-12 16:43*/
public classProgram2 {public static voidmain(String[] args) {//1,参数类型可以省略//2,假如只有一个参数,()括号可以省略//3,如果方法体只有一条语句,{}大括号可以省略//4,如果方法体中唯一的语句是return返回语句,那省略大括号的同事return也要省略//无参数无返回值
If1 if1=()->System.out.println("无参数无返回值");
if1.test();//单个参数无返回值
If2 if2=a->System.out.println("单个参数无返回值 a="+a);
if2.test(3);//两个参数无返回值
If3 if3=(a,b)->{
System.out.println("两个参数无返回值 a+b="+(a+b));
};
if3.test(2,3);//无参数有返回值
If4 if4=()->100;
System.out.println(if4.test());//单个参数有返回值
If5 if5=a->{
System.out.print("单个参数有返回值");returna;
};
System.out.println(if5.test(200));//多个参数有返回值 参数类型可以省略
If6 if6=(a,b)->a+b;
System.out.println(if6.test(1,2));
}
}
方法引用
有时候多个lambda表达式实现函数是一样的话,我们可以封装成通用方法,以便于维护;
这时候可以用方法引用实现:
语法是:对象::方法
假如是static方法,可以直接 类名::方法
实例如下:
public classProgram2 {public static voidmain(String[] args) {//方法引用//语法://static方法 类名::方法名//普通方法 对象名::方法名
Program2 program2=newProgram2();
If5 if5=program2::test;
If5 if52=Program2::test2;
System.out.println(if5.test(1));
System.out.println(if52.test(1));
}public int test(inta){return a-2;
}public static int test2(inta){return a-2;
}
}
构造方法引用
如果函数式接口的实现恰好可以通过调用一个类的构造方法来实现,
那么就可以使用构造方法引用;
语法:类名::new
实例:
先定义一个Dog实体,实现无参和有参构造方法;
public classDog {privateString name;private intage;publicDog() {
System.out.println("无参构造方法");
}public Dog(String name, intage) {
System.out.println("有参构造方法");this.name =name;this.age =age;
}publicString getName() {returnname;
}public voidsetName(String name) {this.name =name;
}public intgetAge() {returnage;
}public void setAge(intage) {this.age =age;
}
@OverridepublicString toString() {return "Dog{" +
"name='" + name + '\'' +
", age=" + age +
'}';
}
}
在定义两个接口:
interfaceDogService{
Dog getDog();
}interfaceDogService2{
Dog getDog(String name,intage);
}
测试:
public classProgram3 {public static voidmain(String[] args) {//普通方式
DogService dogService=()->{return newDog();
};
dogService.getDog();//简化方式
DogService dogService2=()->newDog();
dogService2.getDog();//构造方法引用
DogService dogService3=Dog::new;
dogService3.getDog();//构造方法引用 有参
DogService2 dogService21=Dog::new;
dogService21.getDog("小米",11);
}
}
执行结果:
无参构造方法
无参构造方法
无参构造方法
有参构造方法
综合实例
下面我们通过一个lambda操作集合的综合实例,来深入体验下Lambda表达式用法;
public classProgram4 {public static voidmain(String[] args) {
List list=new ArrayList<>();
list.add(new Dog("aa",1));
list.add(new Dog("bb",4));
list.add(new Dog("cc",3));
list.add(new Dog("dd",2));
list.add(new Dog("ee",5));//排序
System.out.println("lambda集合排序");
list.sort((o1,o2)->o1.getAge()-o2.getAge());
System.out.println(list);//遍历集合
System.out.println("lambda遍历集合");
list.forEach(System.out::println);
}
}
运行输出:
lambda集合排序
[Dog{name='aa', age=1}, Dog{name='dd', age=2}, Dog{name='cc', age=3}, Dog{name='bb', age=4}, Dog{name='ee', age=5}]
lambda遍历集合
Dog{name='aa', age=1}
Dog{name='dd', age=2}
Dog{name='cc', age=3}
Dog{name='bb', age=4}
Dog{name='ee', age=5}
我们来分析下集合的sort方法,
sort方法里有一个Comparator接口,再点进去看下:
我们通过lambda就可以轻松实现排序:
(o1,o2)->o1.getAge()-o2.getAge()
再看下集合的forEach方法,点进去:
有个消费者Consumer接口,再点进去:
接口里有个接口参数的accept的方法;
所以我们直接方法引用 直接输出每次的遍历值即可;
System.out::println
@FunctionalInterface注解
前面我们会发现Consumer接口,Comparator接口都有
@FunctionalInterface注解;
这个注解是函数式接口注解,所谓的函数式接口,当然首先是一个接口,然后就是在这个接口里面只能有一个抽象方法。
这种类型的接口也称为SAM接口,即Single Abstract Method interfaces
特点
接口有且仅有一个抽象方法
允许定义静态方法
允许定义默认方法
允许java.lang.Object中的public方法
该注解不是必须的,如果一个接口符合"函数式接口"定义,那么加不加该注解都没有影响。加上该注解能够更好地让编译器进行检查。如果编写的不是函数式接口,但是加上了@FunctionInterface,那么编译器会报错
实例
//正确的函数式接口
@FunctionalInterfacepublic interfaceTestInterface {//抽象方法
public voidsub();//java.lang.Object中的public方法
publicboolean equals(Object var1);//默认方法
public default voiddefaultMethod(){
}//静态方法
public static voidstaticMethod(){
}
}//错误的函数式接口(有多个抽象方法)
@FunctionalInterfacepublic interfaceTestInterface2 {voidadd();voidsub();
}
系统内置函数式接口
Java8的推出,是以Lambda重要特性,一起推出的,其中系统内置了一系列函数式接口;
再jdk的java.util.function包下,有一系列的内置函数式接口:
比如常用的Consumer,Comparator,Predicate,Supplier等;
Lambda表达式视频教程
感谢各位兄弟姐妹关注,锋哥为了大伙能更深刻的掌握Lambda的原理和应用,专门录制了一期视频教程。主要以IDEA开发工具,来讲解lambda表达式,希望小伙伴们快速的掌握。
纸上得来终觉浅,绝知此事要躬行。
需要多实战,多思考
------------------------------------------------------------------------------------------------------------------------------
作者:java1234_小锋
版权:本站使用「CC BY 4.0」创作共享协议,转载请在文章明显位置注明作者及出处。
------------------------------------------------------------------------------------------------------------------------------
文章浏览阅读1k次。通过使用ajax方法跨域请求是浏览器所不允许的,浏览器出于安全考虑是禁止的。警告信息如下:不过jQuery对跨域问题也有解决方案,使用jsonp的方式解决,方法如下:$.ajax({ async:false, url: 'http://www.mysite.com/demo.do', // 跨域URL ty..._nginx不停的xhr
文章浏览阅读2k次。关于在 Oracle 中配置 extproc 以访问 ST_Geometry,也就是我们所说的 使用空间SQL 的方法,官方文档链接如下。http://desktop.arcgis.com/zh-cn/arcmap/latest/manage-data/gdbs-in-oracle/configure-oracle-extproc.htm其实简单总结一下,主要就分为以下几个步骤。..._extproc
文章浏览阅读1.5w次。linux下没有上面的两个函数,需要使用函数 mbstowcs和wcstombsmbstowcs将多字节编码转换为宽字节编码wcstombs将宽字节编码转换为多字节编码这两个函数,转换过程中受到系统编码类型的影响,需要通过设置来设定转换前和转换后的编码类型。通过函数setlocale进行系统编码的设置。linux下输入命名locale -a查看系统支持的编码_linux c++ gbk->utf8
文章浏览阅读750次。今天准备从生产库向测试库进行数据导入,结果在imp导入的时候遇到“ IMP-00009:导出文件异常结束” 错误,google一下,发现可能有如下原因导致imp的数据太大,没有写buffer和commit两个数据库字符集不同从低版本exp的dmp文件,向高版本imp导出的dmp文件出错传输dmp文件时,文件损坏解决办法:imp时指定..._imp-00009导出文件异常结束
文章浏览阅读143次。当下是一个大数据的时代,各个行业都离不开数据的支持。因此,网络爬虫就应运而生。网络爬虫当下最为火热的是Python,Python开发爬虫相对简单,而且功能库相当完善,力压众多开发语言。本次教程我们爬取前程无忧的招聘信息来分析Python程序员需要掌握那些编程技术。首先在谷歌浏览器打开前程无忧的首页,按F12打开浏览器的开发者工具。浏览器开发者工具是用于捕捉网站的请求信息,通过分析请求信息可以了解请..._初级python程序员能力要求
文章浏览阅读7.6k次,点赞2次,收藏6次。@Service标注的bean,类名:ABDemoService查看源码后发现,原来是经过一个特殊处理:当类的名字是以两个或以上的大写字母开头的话,bean的名字会与类名保持一致public class AnnotationBeanNameGenerator implements BeanNameGenerator { private static final String C..._@service beanname
文章浏览阅读6.9w次,点赞73次,收藏463次。1.前序创建#include<stdio.h>#include<string.h>#include<stdlib.h>#include<malloc.h>#include<iostream>#include<stack>#include<queue>using namespace std;typed_二叉树的建立
文章浏览阅读7.1k次。在Asp.net上使用Excel导出功能,如果文件名出现中文,便会以乱码视之。 解决方法: fileName = HttpUtility.UrlEncode(fileName, System.Text.Encoding.UTF8);_asp.net utf8 导出中文字符乱码
文章浏览阅读2.1k次,点赞4次,收藏23次。第一次实验 词法分析实验报告设计思想词法分析的主要任务是根据文法的词汇表以及对应约定的编码进行一定的识别,找出文件中所有的合法的单词,并给出一定的信息作为最后的结果,用于后续语法分析程序的使用;本实验针对 PL/0 语言 的文法、词汇表编写一个词法分析程序,对于每个单词根据词汇表输出: (单词种类, 单词的值) 二元对。词汇表:种别编码单词符号助记符0beginb..._对pl/0作以下修改扩充。增加单词
文章浏览阅读773次。我在使用adb.exe时遇到了麻烦.我想使用与bash相同的adb.exe shell提示符,所以我决定更改默认的bash二进制文件(当然二进制文件是交叉编译的,一切都很完美)更改bash二进制文件遵循以下顺序> adb remount> adb push bash / system / bin /> adb shell> cd / system / bin> chm..._adb shell mv 权限
文章浏览阅读6.8k次,点赞12次,收藏125次。1. 单目相机标定引言相机标定已经研究多年,标定的算法可以分为基于摄影测量的标定和自标定。其中,应用最为广泛的还是张正友标定法。这是一种简单灵活、高鲁棒性、低成本的相机标定算法。仅需要一台相机和一块平面标定板构建相机标定系统,在标定过程中,相机拍摄多个角度下(至少两个角度,推荐10~20个角度)的标定板图像(相机和标定板都可以移动),即可对相机的内外参数进行标定。下面介绍张氏标定法(以下也这么称呼)的原理。原理相机模型和单应矩阵相机标定,就是对相机的内外参数进行计算的过程,从而得到物体到图像的投影_相机-投影仪标定
文章浏览阅读2.2k次。文章目录Wayland 架构Wayland 渲染Wayland的 硬件支持简 述: 翻译一篇关于和 wayland 有关的技术文章, 其英文标题为Wayland Architecture .Wayland 架构若是想要更好的理解 Wayland 架构及其与 X (X11 or X Window System) 结构;一种很好的方法是将事件从输入设备就开始跟踪, 查看期间所有的屏幕上出现的变化。这就是我们现在对 X 的理解。 内核是从一个输入设备中获取一个事件,并通过 evdev 输入_wayland