用户 对象 User:

package com.java;

public class User {
String name;
int 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;
} public User(String name, int age) {
super();
this.name = name;
this.age = age;
} @Override
public String toString() {
return "User [name=" + name + ", age=" + age + "]";
} }

需求1:从所有的用户中 找出 age大于15的用户

package com.java;

import java.util.ArrayList;
import java.util.List; public class Test { public static List<User> users = new ArrayList<>();
static { User user = new User("张三", 15); users.add(user);
User user1 = new User("李四", 26);
users.add(user1); } public List<User> findAgeGreater15(List<User> users, int age) {
List<User> tempUser = new ArrayList<>();
for (User user : users) {
if (user != null) {
if (user.getAge() > age) {
tempUser.add(user);
}
}
}
return tempUser;
} public static void main(String[] args) {
Test test = new Test();
List<User> findAgeGreater15 = test.findAgeGreater15(users, 15);
for (User user : findAgeGreater15) {
System.out.println(user);
}
}

要实现 上面的需求其实有很多种方法,讲一个基本的方法 和  使用 java1.8 Lambda 方法 实现该需求:

首先:java1.8  提供了 函数式编程(概念可百度)需要 提供一个接口:(不包括 defulet方法 和 static方法)

  

package com.java;

@FunctionalInterface
public interface UserInterface {
boolean filter(int age); }
    public List<User> findAgeGreater15(List<User> users, UserInterface userInterface) {
List<User> tempUser = new ArrayList<>();
for (User user : users) {
if (user != null) {
if (userInterface.filter(user.getAge())) {
tempUser.add(user);
}
}
}
return tempUser;
} public static void main(String[] args) {
Test test = new Test();
List<User> findAgeGreater15 = test.findAgeGreater15(users, (int a) -> {
return a > 15;
});
for (User user : findAgeGreater15) {
System.out.println(user);
}
}

关于  test.findAgeGreater15(users, (int a) -> {return a > 15;}); 调用 findAgeGreater15 方法的时候  参数类型(有两个 一个 List<User> 一个 UserInterface ):
  我这是这样理解的, 调用该方法的时候  将 (int a) -> {return a > 15;} 这个函数 当成一个 UserInterface的参数类型 传入该方法中,在 findAgeGreater15  方法体中

 if (userInterface.filter(user.getAge())) {
tempUser.add(user);
}

.filter(user.getAge()) 执行的方法 就是 判断 user.getAge() 是否 大于 15   user.getAge()类似于 变量a 只要 满足 user.getAge() >15 则返回true。

关于Lamabda 表达式规则:(参数) ->(分割参数和表达式)   表达式

关于 参数的写法:参数可以可以没有 (和定义的接口 参数列表有关系)

  1. 没有则可以写成:List<User> findAgeGreater15 = test.findAgeGreater15(users, () -> System.out.println("执行完成"));
  2. 一个参数可以写成  List<User> findAgeGreater15 = test.findAgeGreater15(users, (int a) -> System.out.println("执行完成"));或者List<User> findAgeGreater15 = test.findAgeGreater15(users, ( a) -> System.out.println("执行完成"));
    当只有一个参数的时候 可以不说明类型,该类型是可导类型
  3. 多个类型的时候  List<User> findAgeGreater15 = test.findAgeGreater15(users, (int a,int b) -> System.out.println("执行完成"))

关于表达式的写法:主要就是 有无返回值(和定义的接口 参数返回值有关系):

  1. 有返回值的写法:必须要有大括号 和分号

    test.findAgeGreater15(users, (int a) -> {
    return a > 15;
    });
  2. 没有返回值的时候:
    test.findAgeGreater15(users, (int a) ->
    System.out.println("没有返回值")
    );

个人感觉 在使用Lambda的时候 比较困难的是 不知道 什么时候该用Lambda 或者 怎么用,这个需要实际中靠自己去 衡量,比如上面解决 age>15的这个需求 ,其实 常规操作 比使用Lambda 更快  使用 Lambda 还要去创建 接口 对 语法 不熟悉 还 要慢慢写。所以 虽然新特性。但是解决的时候 还是得看需求,别整复杂了,在写两个可能比较常用的Lambda表达式用处:

    public static void main(String[] args) {
new Thread(new Runnable() {
@Override
public void run() {
System.out.println("一般写法");
}
}).start();
new Thread(() -> System.out.println("Lambda写法")).start();
;
}

对一个集合从大到小进行排序:

public static void main(String[] args) {
List<Integer> list = Arrays.asList(15, -1, 2, 9, 12);
list.sort((Integer a, Integer b) -> b.compareTo(a));
for (Integer integer : list) {
System.out.println(integer);
}

}

java1.8新特性(一)的更多相关文章

  1. java1.8新特性之stream流式算法

    在Java1.8之前还没有stream流式算法的时候,我们要是在一个放有多个User对象的list集合中,将每个User对象的主键ID取出,组合成一个新的集合,首先想到的肯定是遍历,如下: List& ...

  2. Stream:java1.8新特性

    原 Stream:java1.8新特性 2017年08月01日 18:15:43 kekeair-zhang 阅读数:392 标签: streamjava1-8新特性 更多 个人分类: 日记 版权声明 ...

  3. java1.7新特性:try-with-resources

    转载:https://blog.csdn.net/fanxiaobin577328725/article/details/53067163 首先看代码: import org.junit.Test; ...

  4. Java1.7新特性

    1.switch语句支持字符串变量 public String getTypeOfDayWithSwitchStatement(String dayOfWeekArg) { String typeOf ...

  5. Java1.8新特性——接口改动和Lambda表达式

    Java1.8新特性——接口改动和Lambda表达式 摘要:本文主要学习了Java1.8的新特性中有关接口和Lambda表达式的部分. 部分内容来自以下博客: https://www.cnblogs. ...

  6. java1.8新特性整理(全)

    版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog.csdn.net/yitian_66/article/deta ...

  7. Java1.8新特性 - Stream流式算法

    一. 流式处理简介   在我接触到java8流式数据处理的时候,我的第一感觉是流式处理让集合操作变得简洁了许多,通常我们需要多行代码才能完成的操作,借助于流式处理可以在一行中实现.比如我们希望对一个包 ...

  8. java1.8新特性

    转自:http://www.oschina.NET/translate/everything-about-Java-8 建议去看原文,此处转载只是为了记录. 这篇文章是对Java8中即将到来的改进做一 ...

  9. java1.8新特性(三 关于 ::的用法)

    java1.8 推出了一种::的语法 用法 身边 基本没人用1.8的新API 目前 我也是只处于学习 运用 阶段 有点 知其然不知其所以然 通过后面的学习,及时查漏补缺 一个类中 有 静态方法 ,非静 ...

随机推荐

  1. linux zip tar 压缩打包命令

    zip 压缩命令:(可压缩文件或目录) 压缩文件: zip new_name.zip  file_name unzip name.zip   解压 压缩文件或目录: 指定解压位置: unzip  na ...

  2. HDU 1873 看病要排队 优先队列

    Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submission(s) ...

  3. UE4 IOS 开发之传感器输入

    Iphone的传感器包括陀螺仪.加速计等. UE4提供了4个按键来收集这些传感器的3维数据.具体位置:ProjectSettings->Input. 其中Tilt数据可以反映Iphone目前的物 ...

  4. &,~,|,^

    与.或.异或的运算   与运算 (“  & ”) 参与运算的两个数据,按照二进制位进行“与运算”.运算规则:0&0=0;   0&1=0;   1&0=0;    1& ...

  5. Go Example--限速

    package main import ( "fmt" "time" ) func main() { requests := make(chan int, 5) ...

  6. oracle修改字符集方法

    查看源数据库字符集 在sql命令行执行,即可查看 cat exp.dmp |od -x|head -1|awk '{print $2 $3}'|cut -c 3-6 例如我的返回结果为0362,对照以 ...

  7. S老师 破坏神学习

    代码质量不高 就不整理了 发上来留个纪念 表示自己写过了 数据库:MySQL,服务端:PhotonServer 视频:https://pan.baidu.com/s/1i4ROaRr 客户端:http ...

  8. day28 1.缓冲区 2.subprocess 3.黏包现象 4.黏包现象解决方案 5.struct

    1.缓冲区: 输入缓冲区  输出缓冲区 2. subprocess的使用import subprocess sub_obj = subprocess.Popen('ls', #系统指令shell=Tr ...

  9. java项目中异常处理情况

    一,基本概念   异常是程序在运行时出现的不正常情况.是Java按照面向对象的思想将问题进行对象封装.这样就方便于操作问题以及处理问题.  异常处理的目的是提高程序的健壮性.你可以在catch和fin ...

  10. 论 业务系统 架构 的 简化 (一) 不需要 MQ

    MQ , 就是 消息队列(Message Queue), 不知从什么时候起, MQ 被用来 搭建 分布式 业务系统 架构, 一个重要作用 就是用来  “削峰”   . 我们 这里 就来 讨论 如何 设 ...