Java8的新特性有:默认方法、函数式接口、lambda表达式、方法引用、Stream、Optional、日期API。

 一、默认方法:

  接口中的方法可以有方法体,但是必须要有static或者default修饰,其他的方法都为抽象方法,由static修饰的方法不能被子接口继承 、方法不能被覆写,只能通过类名.方法名调用;由default修饰的方法可以被子接口继承,也可以被覆写,调用通过实现类的对象调用。

二、函数式接口:

  接口中有且仅有一个抽象方法,一般都有@FuntionalInterface注解,即使没有注解它还是函数式接口。

常见的函数式接口:Comparetor、Runnable。

三、lambda表达式:

  可以看成是对匿名内部类的简写,使用lambda表达式的接口必须为函数式接口;

    注:匿名内部类会编译产生两个class文件,但lambda表达式只会编译产生一个class文件。

    (参数1,参数2…)表示参数列表;->表示连接符;{}内部是方法体
    1、=右边的类型会根据左边的函数式接口类型自动推断;
    2、如果形参列表为空,只需保留();
    3、如果形参只有1个,()可以省略,只需要参数的名称即可;
    4、如果执行语句只有1句,且无返回值,{}可以省略,若有返回值,则若想省去{},则必须同时省略return,且执行语句也保证只有1句;
    5、形参列表的数据类型会自动推断;

    6、lambda表达式中使用的局部变量默认会被final修饰,不管这个局部变量是在lamdba表达式里定义的还是在表达式外定义的。因此只要是lambda表达式中使用过的局部变量就不能再修改了,不管在什么位置。

 

四、方法引用:

    4.1 构造方法引用:

//匿名内部类
PersonFacotry facotry = new PersonFacotry() {
  @override
  public Person createPerson(String name, Integer age){
    //其他操作
    return new Person (name, age);
  }
};
//lambda表达式写法
PersonFacotry facotry1 = (name, age) -> new Person (name, age); //lambda表达式简写(这种写法的函数式接口有几个参数,就调用其对应参数个数的构造方法)
PersonFacotry facotry2 = Person:: new; Person person = facotry.createPerson ( name: "某某某", age: 100) ;
System.out.println(person);

    

    4.2静态方法引用

public class Test{
public static void main(string[] args) {
//匿名内部类方式
Parseinterface pil = new ParseInterface(){
@override
public int parse(string str) {
return Integer.parselnt(str);
}
}; // Lambda表达式常规写法
ParseInterface pi2 = str->Integer.parseInt(str); // Lambda表达式简写
ParseInterface pi3 = Integer::parseInt;
}
}

    4.3实例方法引用

  Java1.8提供了一个函数式接口Function,接受两个参数

  匿名内部类方式

    string str ="Hello.world";
//匿名内部类的方式
Function<String,Boolean> func1= new Function<String,Boolean> (){
@override
public Boolean apply(strinq suffix) {
return str.endswith (suffix);
}
};

  Lambda表达式常规写法

// Lambda表达式常规写法
String str = "Hello.world";
Function<String,Boolean> func3 = t -> str.endsWith(t);
System.out.println(func3.apply("world"));

  Lambda表达式简写

// Lambda表达式常规写法
String str = "Hello.world";
Function<String,Boolean> func2 = t -> str::endsWith;
System.out.println(func2.apply("world"));

五、Stream:

    Java 8 API添加了一个新的抽象称为流Stream,Stream API可以极大提高Java程序员的生产力,让程序员写出高效率、干净、简洁的代码。

      注意:和IO中的流是完全不一样的。

    在 Java 8 中, 集合接口有两个方法来生成流:

      stream() − 为集合创建串行流。(常用)

      parallelStream() − 为集合创建并行流。

  Stream常用方法:

  ForEach:

      Stream 提供了新的方法 'forEach' 来迭代流中的每个数据。以下代码片段使用 forEach 输出了10个随机数:

Random random = new Random();

random.ints().limit(10).forEach(System.out::println);

  map:

    map 方法用于映射每个元素到对应的结果,以下代码片段使用 map 输出了元素对应的平方数:

List<Integer> numbers = Arrays.asList(3, 2, 2, 3, 7, 3, 5);

// 获取对应的平方数 

List<Integer> squaresList = numbers.stream().map( i -> i*i).distinct().collect(Collectors.toList());

  filter:

    filter 方法用于通过设置的条件过滤出元素。以下代码片段使用 filter 方法过滤出空字符串:

List<String>strings = Arrays.asList("abc", "", "bc", "efg", "abcd","", "jkl"); 

// 获取空字符串的数量 
int count = strings.stream().filter(string -> string.isEmpty()).count();

  limit:

    limit 方法用于获取指定数量的流。 以下代码片段使用 limit 方法打印出 10 条数据:

Random random = new Random();

random.ints().limit(10).forEach(System.out::println);

  sorted:

    sorted 方法用于对流进行排序。以下代码片段使用 sorted 方法对输出的 10 个随机数进行排序:

Random random = new Random();

random.ints().limit(10).sorted().forEach(System.out::println);

  并行(parallel)程序:

    parallelStream 是流并行处理程序的代替方法。以下实例我们使用 parallelStream 来输出空字符串的数量:

List<String> strings = Arrays.asList("abc", "", "bc", "efg", "abcd","", "jkl");

// 获取空字符串的数量 

int count = strings.parallelStream().filter(string -> string.isEmpty()).count();

    我们可以很容易的在顺序运行和并行直接切换。

  Collectors:

Collectors 类实现了很多归约操作,例如将流转换成集合和聚合元素。Collectors 可用于返回列表或字符串:

List<String>strings = Arrays.asList("abc", "", "bc", "efg", "abcd","", "jkl");

List<String> filtered = strings.stream().filter(string -> !string.isEmpty()).collect(Collectors.toList());

System.out.println("筛选列表: " + filtered);

String mergedString = strings.stream().filter(string -> !string.isEmpty()).collect(Collectors.joining(", "));

System.out.println("合并字符串: " + mergedString);

六、Optional:

  Optional对象可以为空,所以Optional 类的引入很好的解决空指针异常。

    通过以下实例来了解Optional类的使用:

Public class User{

  private String name;

  private String password;

  ....

}

以往的判断方式:

public class Mytest{

  public static void main(String[] args){

       User user = new User();

    User.setPassword(“admin”);

    String name = getPwd(user);

    System.out.println(name);

  }

  public static String getPwd(User u){

    if(u==null){

      return “unknown”;

  }

   return u.getPassword();

}

使用Optional:

public static String getPwd(User u){

  return Optional.ofNullable(u)

          .map(user->user.getPassword())

          .orElse(“unknown”);

};

七、日期Api:

Jdk1.8给我们提供了三个本地日期时间类:LocalDate、LocalTime 和 LocalDateTime 类。

在不需要处理时区问题的时候,使用本地日期时间API(LocalDate、LocalTime 和 LocalDateTime) :

// 获取当前的日期时间

 LocalDateTime currentTime = LocalDateTime.now();

 System.out.println("当前时间: " + currentTime);

LocalDate date1 = currentTime.toLocalDate();

System.out.println("date1: " + date1);

Month month = currentTime.getMonth();

int day = currentTime.getDayOfMonth();

int seconds = currentTime.getSecond();

System.out.println("月: " + month +", 日: " + day +", 秒: " + seconds);

在需要处理时区的时候,使用时区的日期时间API(ZonedDateTime ):

ZonedDateTime dd= ZonedDateTime.now();
System.out.println(dd);
ZonedDateTime date1 = ZonedDateTime.parse(dd.toString());
System.out.println("date1: " + date1);
ZoneId id = ZoneId.of(ZoneId.SHORT_IDS.get("CTT"));
System.out.println("ZoneId: " + id);
ZoneId currentZone = ZoneId.systemDefault();
System.out.println("当期时区: " + currentZone);

JAVA 8 的新特性的更多相关文章

  1. [转] Java 8的新特性

    简介 毫无疑问,Java 8是Java自Java 5(发布于2004年)之后的最重要的版本.这个版本包含语言.编译器.库.工具和JVM等方面的十多个新特性.在本文中我们将学习这些新特性,并用实际的例子 ...

  2. Java 8的新特性—终极版

    作者:杜琪[译] 原文链接:http://www.jianshu.com/p/5b800057f2d8 1. 简介 毫无疑问,Java 8是Java自Java 5(发布于2004年)之后的最重要的版本 ...

  3. Java 9和Java 10的新特性

    http://www.infoq.com/cn/news/2014/09/java9 Java 9新特性汇总 继2014年3月份Java 8发布之后,Open JDK加快了开发速度, Java 9的发 ...

  4. Atitit..jdk java 各版本新特性 1.0 1.1 1.2 1.3 1.4 1.5(5.0) 1.6(6.0) 7.0 8.0 9.0 attilax 大总结

    Atitit..jdk java 各版本新特性 1.0 1.1 1.2 1.3 1.4 1.5(5.0) 1.6(6.0) 7.0 8.0 9.0 attilax 大总结 1.1. Java的编年史2 ...

  5. JDK 15 JAVA 15的新特性展望

    目录 JEP 371: Hidden Classes JEP 372: 删除 Nashorn JavaScript Engine JEP 377: 新的垃圾回收器ZGC正式上线了 JEP 378: T ...

  6. Java最近版本新特性使用介绍

    本文来自http://blog.csdn.net/liuxian13183/ ,引用必须注明出处! 在阅读<Thinking in Java>的过程中,并发这一章出现不少新特性,工作中也有 ...

  7. Java API —— JDK5新特性

    JDK5新特性         自动拆装箱.泛型.增强for.静态导入.可变参数.枚举   1.增强for概述         1)简化数组和Collection集合的遍历         2)格式: ...

  8. Java SE 6 新特性: Java DB 和 JDBC 4.0

    http://www.ibm.com/developerworks/cn/java/j-lo-jse65/index.html 长久以来,由于大量(甚至几乎所有)的 Java 应用都依赖于数据库,如何 ...

  9. Java SE 6 新特性: 对脚本语言的支持

    2006 年底,Sun 公司发布了 Java Standard Edition 6(Java SE 6)的最终正式版,代号 Mustang(野马).跟 Tiger(Java SE 5)相比,Musta ...

  10. Java SE 6 新特性: 编译器 API

    新 API 功能简介 JDK 6 提供了在运行时调用编译器的 API,后面我们将假设把此 API 应用在 JSP 技术中.在传统的 JSP 技术中,服务器处理 JSP 通常需要进行下面 6 个步骤: ...

随机推荐

  1. react生命周期钩子函数

    render在更新阶段和挂在阶段都会执行 class App extends Component { render() { return ( <div> <h1>reacet生 ...

  2. ent 基本使用十八 查询谓词

    ent 生成的代码包含了比较完整的查询谓词 字段谓词 Bool: =, != Numeric: =, !=, >, <, >=, <=, IN, NOT IN Time: =, ...

  3. Using the Repository and Unit Of Work Pattern in .net core

    A typical software application will invariably need to access some kind of data store in order to ca ...

  4. 12-网页,网站,微信公众号基础入门(编写后台PHP程序,实现Airkiss配网)

    https://www.cnblogs.com/yangfengwu/p/11067590.html 首先说一下,这两个地方需要配置一样 网站根目录建个文件夹 airkiss的文件夹 里面放上 ind ...

  5. AtCoder Regular Contest 069 F Flags 二分,2-sat,线段树优化建图

    AtCoder Regular Contest 069 F Flags 二分,2-sat,线段树优化建图 链接 AtCoder 大意 在数轴上放上n个点,点i可能的位置有\(x_i\)或者\(y_i\ ...

  6. 大数定律(Law of Large Numbers)

    大数定律:每次从总体中随机抽取1个样本,这样抽取很多次后,样本的均值会趋近于总体的期望.也可以理解为:从总体中抽取容量为n的样本,样本容量n越大,样本的均值越趋近于总体的期望.当样本容量极大时,样本均 ...

  7. Javascript总结(全)

    说明 个人感觉总结得很好忍不住要分享,转载自github地址,作者博客原文发现打不开,于是复制粘贴到此处,如有侵权,请联系本人删除. Type class TypeFn { isString (o) ...

  8. linux下 调试C#代码

    参考两位大神的帖子: https://blog.csdn.net/soband_xiang/article/details/82914195 https://blog.csdn.net/weixin_ ...

  9. shell脚本获取传入参数的个数

    ts.sh #!/bin/bash echo $# 输出 [root@redhat6 ~]# ./ts.sh para1 [root@redhat6 ~]# ./ts.sh para1 para2 [ ...

  10. 奇袭 CodeForces 526F Pudding Monsters 题解

    考场上没有认真审题,没有看到该题目的特殊之处: 保证每一行和每一列都恰有一只军队,即每一个Xi和每一个Yi都是不一样 的. 于是无论如何也想不到复杂度小于$O(n^3)$的算法, 只好打一个二维前缀和 ...