JDK8新特性
1.Lambda表达式
2.Stream函数式操作流元素集合 3.接口新增:默认方法与静态方法 4.方法引用,与Lambda表达式联合使用 5.引入重复注解 6.类型注解
7.最新的Date/Time API (JSR 310) 8.新增base64加解密API 9.数组并行(parallel)操作
10.JVM的PermGen空间被移除:取代它的是Metaspace(JEP 122)元空间
Demo /** *
* @ClassName:JDK8_features * @Description:JDK8新特性 * @author diandian.zhang
* @date 2017年4月17日上午9:13:24 */
public class JDK8_features {
public List
* 1.Lambda表达式 */ @Test
public void testLambda(){
list.forEach(System.out::println);
list.forEach(e -> System.out.println(\方式二:\ } /**
* 2.Stream函数式操作流元素集合 */ @Test
public void testStream(){
List
System.out.println(\求和:\ .stream()//转成Stream
.filter(team -> team!=null)//过滤 .distinct()//去重
.mapToInt(num->num*2)//map操作 .skip(2)//跳过前2个元素 .limit(4)//限制取前4个元素
.peek(System.out::println)//流式处理对象函数 .sum());// } /**
* 3.接口新增:默认方法与静态方法
* default 接口默认实现方法是为了让集合类默认实现这些函数式处理,而不用修改现有代码
* (List继承于Iterable
public void testDefaultFunctionInterface(){
//可以直接使用接口名.静态方法来访问接口中的静态方法 JDK8Interface1.staticMethod();
//接口中的默认方法必须通过它的实现类来调用 new JDK8InterfaceImpl1().defaultMethod(); //多实现类,默认方法重名时必须复写 new JDK8InterfaceImpl2().defaultMethod(); }
public class JDK8InterfaceImpl1 implements JDK8Interface1 {
//实现接口后,因为默认方法不是抽象方法,重写/不重写都成! // @Override
// public void defaultMethod(){
// System.out.println(\接口中的默认方法\// } }
public class JDK8InterfaceImpl2 implements JDK8Interface1,JDK8Interface2 { //实现接口后,默认方法名相同,必须复写默认方法 @Override
public void defaultMethod() { //接口的
JDK8Interface1.super.defaultMethod();
System.out.println(\实现类复写重名默认方法!!!!\ } }
/**
* 4.方法引用,与Lambda表达式联合使用 */ @Test
public void testMethodReference(){
//构造器引用。语法是Class::new,或者更一般的Class< T >::new,要求构造器方法是没有参数;
final Car car = Car.create( Car::new ); final List< Car > cars = Arrays.asList( car );
//静态方法引用。语法是Class::static_method,要求接受一个Class类型的参数; cars.forEach( Car::collide );
//任意对象的方法引用。它的语法是Class::method。无参,所有元素调用; cars.forEach( Car::repair );
//特定对象的方法引用,它的语法是instance::method。有参,在某个对象上调用方法,将列表元素作为参数传入;
final Car police = Car.create( Car::new ); cars.forEach( police::follow ); }
public static class Car {
public static Car create( final Supplier< Car > supplier ) { return supplier.get(); }
public static void collide( final Car car ) {
System.out.println( \静态方法引用 \ }
public void repair() {
System.out.println( \任意对象的方法引用 \ }
public void follow( final Car car ) {
System.out.println( \特定对象的方法引用 \ } } /**
* 5.引入重复注解 * 1.@Repeatable
* 2.可以不用以前的“注解容器”写法,直接写2次相同注解即可 *
* Java 8在编译器层做了优化,相同注解会以集合的方式保存,因此底层的原理并没有
变化。 */ @Test
public void RepeatingAnnotations(){ RepeatingAnnotations.main(null); } /**
* 6.类型注解
* 新增类型注解:ElementType.TYPE_USE 和ElementType.TYPE_PARAMETER(在Target上) * */ @Test
public void ElementType(){ Annotations.main(null); } /**
* 7.最新的Date/Time API (JSR 310) */ @Test
public void DateTime(){ //1.Clock
final Clock clock = Clock.systemUTC(); System.out.println( clock.instant() ); System.out.println( clock.millis() );
//2. ISO-8601格式且无时区信息的日期部分 final LocalDate date = LocalDate.now();
final LocalDate dateFromClock = LocalDate.now( clock );
System.out.println( date );
System.out.println( dateFromClock );
// ISO-8601格式且无时区信息的时间部分 final LocalTime time = LocalTime.now();
final LocalTime timeFromClock = LocalTime.now( clock );
System.out.println( time );
System.out.println( timeFromClock );
// 3.ISO-8601格式无时区信息的日期与时间
final LocalDateTime datetime = LocalDateTime.now();
final LocalDateTime datetimeFromClock = LocalDateTime.now( clock );
System.out.println( datetime );
System.out.println( datetimeFromClock );
// 4.特定时区的日期/时间,
final ZonedDateTime zonedDatetime = ZonedDateTime.now();
final ZonedDateTime zonedDatetimeFromClock = ZonedDateTime.now( clock ); final ZonedDateTime zonedDatetimeFromZone ZonedDateTime.now( ZoneId.of( \
System.out.println( zonedDatetime );
System.out.println( zonedDatetimeFromClock ); System.out.println( zonedDatetimeFromZone );
//5.在秒与纳秒级别上的一段时间
final LocalDateTime from = LocalDateTime.of( 2014, Month.APRIL, 16, 0, 0, 0 ); final LocalDateTime to = LocalDateTime.of( 2015, Month.APRIL, 16, 23, 59, 59 );
final Duration duration = Duration.between( from, to );
System.out.println( \ System.out.println( \ } /**
* 8.新增base64加解密API */ @Test
public void testBase64(){
final String text = \就是要测试加解密!!abjdkhdkuasu!!@@@@\ String encoded = Base64.getEncoder()
.encodeToString( text.getBytes( StandardCharsets.UTF_8 ) ); System.out.println(\加密后=\
final String decoded = new String(
Base64.getDecoder().decode( encoded ), StandardCharsets.UTF_8 );
System.out.println( \解密后=\ } /**
* 9.数组并行(parallel)操作 */ @Test
=
百度搜索“77cn”或“免费范文网”即可找到本站免费阅读全部范文。收藏本站方便下次阅读,免费范文网,提供经典小说综合文库JDK8新特性在线全文阅读。
相关推荐: