Java8新特性

一、总体变化

1、Se8

1、 引入lambda

2、增强了运行JavaScript引擎

3、新的日期/时间api类

4、一套简洁的配置文件

5、Jvm去出了永久代

6、增强注解,编译期间即可发现空指针

2、Se Embeded8

用于嵌入式,不关心

3、Me8

适用于机顶盒开发等exe程序开发

1、 与se8一直的java语言和api

2、支持最新的web协议

3、 全新的应用模型

4、先进的安全功能

5、用于电源管理及多种外部设备的api


jdk中几种基本组成定义:

Bin文件夹:二进制文件,可执行文件夹。

javac.exe:编译java源程序为字节码 

java.exe:执行字节码为java程序

Class path:调用系统相关的类:%JAVA_HOME%/dt.jar; %JAVA_HOME%/tools.jar;

二、新增stream类

1、stream类:

1、在Java8中定义为泛型接口

2、接口代表数据流

3、不是数据结构,不存储数据

4、通过管道操作数据

创建实现类对象实例:

List perple = new ArrayList()<>;

Stream stream = people.stream();

2、stream管道

管道代表一个操作序列

管道组件:

1、 数据集

2、零个/多个中间业务:过滤器

3、一个终端操作,如foreach循环

3、stream过滤器

给定条件,过滤出新的数据,并返回stream对象 。

方法为: .filter()

4、几种子类

DoubleStream接口:元素类型是double的数据源

常用方法:

1、 max().getAsDouble():获取流中数据集最大值

2、 min().getAsDouble():获取流中数据集最小值

3、 average():获取流中平均值

4、 mapToDouble() 转为double数据源

三、新增日期/时间API类

1、Localdate类

使用ISO日历表示年、月、日

常用方法:

1、 now():获取系统日期

2、 of(year, month, dayofmonth) 获取localdate对象

3、 getYear()/getMonthValue()/getDayOfMonth()

2、LocalTime类

标识一天中的时间

常用方法:

1、now:获取系统时间

2、of(hour, minute,

second) 获取localtime对象

3、getHour()/getMinute()/getSecond()

3、LcoalDateTime类

获取系统当前时间

常用方法

1、now:获取系统时间

2、of(year, month,

dayofmonth , hour, minute, second) 获取localDateTime对象

3、getYear()/getMonthValue()/getDayOfMonth()/

getHour()/getMinute()/getSecond()

4、DateTimeFormatter类

用于将字符串解析成日期对象

常用方法:

1、 ofPattern(pattern): 按照pattern字符串指定格式创建DateTimeFormatter对象

2、 LocalDateTime.parse(strDate, formatter)解析字符串并返回LocalDateTime对象

5、ZonedDateTime类

处理日期/时间与相应时区

1、 now():获取当前时间

2、format(dateTimeFormatter) 格式化成字符串

四、新增函数式接口及Lambda表达式

1、Java8接口变化

1、 增加了default和static方法,可以有方法体

2、 Default属于实例方法,static属于类(接口)方法

3、Static方法不会被继承,静态变量会被继承。

2、函数式接口

定义:接口类中只有一个抽象方法(包括继承的),且用@FunctionalInterface强制只有一个抽象方法。(注解:java5开始引入的。注解是对字节码文件进行一段说明,方便java.exe执行器执行。)


Lambda表达式只能针对函数式接口使用。


从Java8开始,接口中可以使用静态方法,也可以默认方法。

默认方法:

1、默认方法必须用default修饰,且必须是public方法,通过匿名内部类实例访问。

2、默认方法可以被接口继承。

3、接口可以继承多个接口,但父接口默认方法必须不同。如果存在重名方法,子接口类中必须重写,明确指定引用父接口默认方法(类.super.重复默认方法名())。

4、对于接口实现类,若同时实现多个接口,默认方法同样存在这种问题。但若实现的多个接口间有上下继承关系,子接口默认方法相当于覆盖父接口方法,不会由问题。

5、若子接口默认方法先实现父接口抽象方法,再去实现父类抽象方法,相当于覆盖父接口抽象方法。

6、接口中的默认方法,可以用this.抽象方法,指向该抽象方法的实现。

7、子接口可以重写父接口方法为抽象方法,去掉父接口行为。

3、Lambda表达式

只能应用于函数式接口,可以认为一种特殊的匿名内部类,但不生成类(class)文件。

组成部分:

1、 参数列表

2、 ‘->”

3、 代码块

4、规则:

    a)    函数式接口只有一个参数可以省略();

    b)    函数式接口的实现中只有一行,{}可以省略掉;

    c)    函数式接口的实现中如果返回只有一行,return一定要省略掉,代码表达式返回值会自动作为方法返回值。

    d)    和匿名内部类一样,如果访问局部变量,局部变量必须是final的。

    e)    引用类方法

            <函数式接口><变量名> = <类> :: <类方法名>;

            //自动把[实参]全部传入引用方法

             <变量名>.<方法名>([实参])

    f)    引用实例方法

            如System.out::println、Arrays.sort。自动把参数传入引用方法内。

            <函数式接口><变量名> = <实例> :: <实例方法名>;

            //自动把[实参]全部传入引用方法

             <变量名>.<方法名>([实参])

案例:

一、 简化runnable接口实现

Runnable r=(参数列表)->{方法体};

r.run();

更简化:只有一句话或返回值

Runnable r=(参数列表)->方法体;

r.run();

你可能感兴趣的:(Java8新特性)