=
考虑集体升级下java8,虽然麻烦些。
=
最全的还是看官方:
摘自:Java 8 新特性 http://www.runoob.com/java/java8-new-features.html
Java8 新增了非常多的特性,我们主要讨论以下几个:
-
Lambda 表达式 − Lambda允许把函数作为一个方法的参数(函数作为参数传递进方法中。
-
方法引用 − 方法引用提供了非常有用的语法,可以直接引用已有Java类或对象(实例)的方法或构造器。与lambda联合使用,方法引用可以使语言的构造更紧凑简洁,减少冗余代码。
-
默认方法 − 默认方法就是一个在接口里面有了一个实现的方法。
-
新工具 − 新的编译工具,如:Nashorn引擎 jjs、 类依赖分析器jdeps。
-
Stream API −新添加的Stream API(java.util.stream) 把真正的函数式编程风格引入到Java中。
-
Date Time API − 加强对日期与时间的处理。
-
Optional 类 − Optional 类已经成为 Java 8 类库的一部分,用来解决空指针异常。
-
Nashorn, JavaScript 引擎 − Java 8提供了一个新的Nashorn javascript引擎,它允许我们在JVM上运行特定的javascript应用。
本篇文章下面还有详细的单篇专题介绍每个功能,以及例子。
可以好好看一下。
正文
JDK9原计划17年上半年就发版,但未成功发版。才发现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
demo基于junit可测。
1 /** 2 * 3 * @ClassName:JDK8_features 4 * @Description:JDK8新特性 5 * @author diandian.zhang 6 * @date 2017年4月17日上午9:13:24 7 */ 8 public class JDK8_features { 9 10 public List<Integer> list = Lists.newArrayList(1,2,3,4,5,6,7,8,9,10); 11 12 /** 13 * 1.Lambda表达式 14 */ 15 @Test 16 public void testLambda(){ 17 list.forEach(System.out::println); 18 list.forEach(e -> System.out.println("方式二:"+e)); 19 } 20 21 /** 22 * 2.Stream函数式操作流元素集合 23 */ 24 @Test 25 public void testStream(){ 26 List<Integer> nums = Lists.newArrayList(1,1,null,2,3,4,null,5,6,7,8,9,10); 27 System.out.println("求和:"+nums 28 .stream()//转成Stream 29 .filter(team -> team!=null)//过滤 30 .distinct()//去重 31 .mapToInt(num->num*2)//map操作 32 .skip(2)//跳过前2个元素 33 .limit(4)//限制取前4个元素 34 .peek(System.out::println)//流式处理对象函数 35 .sum());// 36 } 37 38 /** 39 * 3.接口新增:默认方法与静态方法 40 * default 接口默认实现方法是为了让集合类默认实现这些函数式处理,而不用修改现有代码 41 * (List继承于Iterable<T>,接口默认方法不必须实现default forEach方法) 42 */ 43 @Test 44 public void testDefaultFunctionInterface(){ 45 //可以直接使用接口名.静态方法来访问接口中的静态方法 46 JDK8Interface1.staticMethod(); 47 //接口中的默认方法必须通过它的实现类来调用 48 new JDK8InterfaceImpl1().defaultMethod(); 49 //多实现类,默认方法重名时必须复写 50 new JDK8InterfaceImpl2().defaultMethod(); 51 } 52 53 public class JDK8InterfaceImpl1 implements JDK8Interface1 { 54 //实现接口后,因为默认方法不是抽象方法,重写/不重写都成! 55 // @Override 56 // public void defaultMethod(){ 57 // System.out.println("接口中的默认方法"); 58 // } 59 } 60 61 public class JDK8InterfaceImpl2 implements JDK8Interface1,JDK8Interface2 { 62 //实现接口后,默认方法名相同,必须复写默认方法 63 @Override 64 public void defaultMethod() { 65 //接口的 66 JDK8Interface1.super.defaultMethod(); 67 System.out.println("实现类复写重名默认方法!!!!"); 68 } 69 } 70 71 /** 72 * 4.方法引用,与Lambda表达式联合使用 73 */ 74 @Test 75 public void testMethodReference(){ 76 //构造器引用。语法是Class::new,或者更一般的Class< T >::new,要求构造器方法是没有参数; 77 final Car car = Car.create( Car::new ); 78 final List< Car > cars = Arrays.asList( car ); 79 //静态方法引用。语法是Class::static_method,要求接受一个Class类型的参数; 80 cars.forEach( Car::collide ); 81 //任意对象的方法引用。它的语法是Class::method。无参,所有元素调用; 82 cars.forEach( Car::repair ); 83 //特定对象的方法引用,它的语法是instance::method。有参,在某个对象上调用方法,将列表元素作为参数传入; 84 final Car police = Car.create( Car::new ); 85 cars.forEach( police::follow ); 86 } 87 88 public static class Car { 89 public static Car create( final Supplier< Car > supplier ) { 90 return supplier.get(); 91 } 92 93 public static void collide( final Car car ) { 94 System.out.println( "静态方法引用 " + car.toString() ); 95 } 96 97 public void repair() { 98 System.out.println( "任意对象的方法引用 " + this.toString() ); 99 } 100 101 public void follow( final Car car ) { 102 System.out.println( "特定对象的方法引用 " + car.toString() ); 103 } 104 } 105 106 /** 107 * 5.引入重复注解 108 * 1.@Repeatable 109 * 2.可以不用以前的“注解容器”写法,直接写2次相同注解即可 110 * 111 * Java 8在编译器层做了优化,相同注解会以集合的方式保存,因此底层的原理并没有变化。 112 */ 113 @Test 114 public void RepeatingAnnotations(){ 115 RepeatingAnnotations.main(null); 116 } 117 118 /** 119 * 6.类型注解 120 * 新增类型注解:ElementType.TYPE_USE 和ElementType.TYPE_PARAMETER(在Target上) 121 * 122 */ 123 @Test 124 public void ElementType(){ 125 Annotations.main(null); 126 } 127 128 /** 129 * 7.最新的Date/Time API (JSR 310) 130 */ 131 @Test 132 public void DateTime(){ 133 //1.Clock 134 final Clock clock = Clock.systemUTC(); 135 System.out.println( clock.instant() ); 136 System.out.println( clock.millis() ); 137 138 //2. ISO-8601格式且无时区信息的日期部分 139 final LocalDate date = LocalDate.now(); 140 final LocalDate dateFromClock = LocalDate.now( clock ); 141 142 System.out.println( date ); 143 System.out.println( dateFromClock ); 144 145 // ISO-8601格式且无时区信息的时间部分 146 final LocalTime time = LocalTime.now(); 147 final LocalTime timeFromClock = LocalTime.now( clock ); 148 149 System.out.println( time ); 150 System.out.println( timeFromClock ); 151 152 // 3.ISO-8601格式无时区信息的日期与时间 153 final LocalDateTime datetime = LocalDateTime.now(); 154 final LocalDateTime datetimeFromClock = LocalDateTime.now( clock ); 155 156 System.out.println( datetime ); 157 System.out.println( datetimeFromClock ); 158 159 // 4.特定时区的日期/时间, 160 final ZonedDateTime zonedDatetime = ZonedDateTime.now(); 161 final ZonedDateTime zonedDatetimeFromClock = ZonedDateTime.now( clock ); 162 final ZonedDateTime zonedDatetimeFromZone = ZonedDateTime.now( ZoneId.of( "America/Los_Angeles" ) ); 163 164 System.out.println( zonedDatetime ); 165 System.out.println( zonedDatetimeFromClock ); 166 System.out.println( zonedDatetimeFromZone ); 167 168 //5.在秒与纳秒级别上的一段时间 169 final LocalDateTime from = LocalDateTime.of( 2014, Month.APRIL, 16, 0, 0, 0 ); 170 final LocalDateTime to = LocalDateTime.of( 2015, Month.APRIL, 16, 23, 59, 59 ); 171 172 final Duration duration = Duration.between( from, to ); 173 System.out.println( "Duration in days: " + duration.toDays() ); 174 System.out.println( "Duration in hours: " + duration.toHours() ); 175 } 176 177 /** 178 * 8.新增base64加解密API 179 */ 180 @Test 181 public void testBase64(){ 182 final String text = "就是要测试加解密!!abjdkhdkuasu!!@@@@"; 183 String encoded = Base64.getEncoder() 184 .encodeToString( text.getBytes( StandardCharsets.UTF_8 ) ); 185 System.out.println("加密后="+ encoded ); 186 187 final String decoded = new String( 188 Base64.getDecoder().decode( encoded ), 189 StandardCharsets.UTF_8 ); 190 System.out.println( "解密后="+decoded ); 191 } 192 193 /** 194 * 9.数组并行(parallel)操作 195 */ 196 @Test 197 public void testParallel(){ 198 long[] arrayOfLong = new long [ 20000 ]; 199 //1.给数组随机赋值 200 Arrays.parallelSetAll( arrayOfLong, 201 index -> ThreadLocalRandom.current().nextInt( 1000000 ) ); 202 //2.打印出前10个元素 203 Arrays.stream( arrayOfLong ).limit( 10 ).forEach( 204 i -> System.out.print( i + " " ) ); 205 System.out.println(); 206 //3.数组排序 207 Arrays.parallelSort( arrayOfLong ); 208 //4.打印排序后的前10个元素 209 Arrays.stream( arrayOfLong ).limit( 10 ).forEach( 210 i -> System.out.print( i + " " ) ); 211 System.out.println(); 212 } 213 214 /** 215 * 10.JVM的PermGen空间被移除:取代它的是Metaspace(JEP 122)元空间 216 */ 217 @Test 218 public void testMetaspace(){ 219 //-XX:MetaspaceSize初始空间大小,达到该值就会触发垃圾收集进行类型卸载,同时GC会对该值进行调整 220 //-XX:MaxMetaspaceSize最大空间,默认是没有限制 221 //-XX:MinMetaspaceFreeRatio在GC之后,最小的Metaspace剩余空间容量的百分比,减少为分配空间所导致的垃圾收集 222 //-XX:MaxMetaspaceFreeRatio在GC之后,最大的Metaspace剩余空间容量的百分比,减少为释放空间所导致的垃圾收集 223 } 224 225 } 引用到的相关类:
1 public interface JDK8Interface1 { 2 3 //1.接口中可以定义静态方法了 4 public static void staticMethod(){ 5 System.out.println("接口中的静态方法"); 6 } 7 8 //2.使用default之后就可以定义普通方法的方法体了 9 public default void defaultMethod(){ 10 System.out.println("接口中的默认方法"); 11 } 12 } 13 14 public interface JDK8Interface2 { 15 16 //接口中可以定义静态方法了 17 public static void staticMethod(){ 18 System.out.println("接口中的静态方法"); 19 } 20 //使用default之后就可以定义普通方法的方法体了 21 public default void defaultMethod(){ 22 System.out.println("接口中的默认方法"); 23 } 24 } 25 26 /** 27 * 28 * @ClassName:RepeatingAnnotations 29 * @Description:重复注解@Repeatable 30 * @author diandian.zhang 31 * @date 2017年3月31日下午3:48:13 32 */ 33 public class RepeatingAnnotations { 34 @Target( ElementType.TYPE ) 35 @Retention( RetentionPolicy.RUNTIME ) 36 public @interface Filters { 37 Filter[] value(); 38 } 39 40 @Target( ElementType.TYPE ) 41 @Retention( RetentionPolicy.RUNTIME ) 42 @Repeatable( Filters.class ) 43 public @interface Filter { 44 String value(); 45 String value2(); 46 }; 47 48 @Filter( value="filter1",value2="111" ) 49 @Filter( value="filter2", value2="222") 50 //@Filters({@Filter( value="filter1",value2="111" ),@Filter( value="filter2", value2="222")}).注意:JDK8之前:1.没有@Repeatable2.采用本行“注解容器”写法 51 public interface Filterable { 52 } 53 54 public static void main(String[] args) { 55 //获取注解后遍历打印值 56 for( Filter filter: Filterable.class.getAnnotationsByType( Filter.class ) ) { 57 System.out.println( filter.value() +filter.value2()); 58 } 59 } 60 } 61 62 /** 63 * 64 * @ClassName:Annotations 65 * @Description:新增类型注解:ElementType.TYPE_USE 和ElementType.TYPE_PARAMETER(在Target上) 66 * @author diandian.zhang 67 * @date 2017年3月31日下午4:39:57 68 */ 69 public class Annotations { 70 @Retention( RetentionPolicy.RUNTIME ) 71 @Target( { ElementType.TYPE_USE, ElementType.TYPE_PARAMETER } ) 72 public @interface NonEmpty { 73 } 74 75 public static class Holder< @NonEmpty T > extends @NonEmpty Object { 76 public void method() throws @NonEmpty Exception { 77 } 78 } 79 80 public static void main(String[] args) { 81 final Holder< String > holder = new @NonEmpty Holder< String >(); 82 @NonEmpty Collection< @NonEmpty String > strings = new ArrayList<>(); 83 } 84 }
=
=
=
相关推荐
aspose-words-21.1-jdk17.jar 处理word转pdf,无水印无文件大小限制,无使用时间限制,可以用于word编辑处理,转pdf等用途。 。由于aspose调用的时候有点消耗内存,操作大文件的时候可能会堆溢出,所以请先设置好...
标题 "graalvm-jdk-17.0.10-windows" 指的是 GraalVM 的一个特定版本,适用于 Windows 操作系统的 Java 开发工具包。GraalVM 是一个高性能的运行时环境,它扩展了 Java 虚拟机(JVM),支持多种编程语言,包括 Java...
在这个特定的案例中,我们关注的是`aspose-words-15.8.0-jdk16.jar`文件,这是一个Java档案(JAR)文件,包含了Aspose.Words的库,版本为15.8.0,它专为使用Java Development Kit(JDK)16的项目设计。此库允许...
使用Aspose.Words for Java完成复杂Word与PDF的导出Demo使用Aspose.Words for Java完成复杂Word与PDF的导出Demo使用Aspose.Words for Java完成复杂Word与PDF的导出Demo
JDK 8是Java历史上的一个重要版本,引入了许多新特性,例如: 1. Lambda表达式:这是一种更简洁、更函数式的编程方式,可以用来创建匿名函数。 2. 方法引用和构造器引用:它们允许直接引用已存在的方法或构造器,而...
通过深入研究`jdk-8u271-windows-x64-demos`提供的示例,开发者可以更好地理解和掌握JDK 8的新特性和最佳实践。这些示例代码不仅有助于理解新功能的工作原理,还能帮助我们在实际项目中更有效地应用这些特性,提升...
本篇文章将详细探讨JDK8的三大关键新特性:Lambda表达式、方法引用来及Stream API。 一、Lambda表达式 Lambda表达式是JDK8中最显著的新特性之一,它简化了对匿名函数的处理,尤其是对于那些只需要一次性的、简单的...
在下载的压缩包“jdk-8u291-windows-x64.rar”中,主要包含的文件是“jdk-8u291-windows-x64.exe”。这是一个可执行文件,用于在Windows 64位系统上安装JDK。安装过程中,它会将必要的Java运行时环境(JRE)和开发...
使用`sudo ln -s /usr/lib/jvm/jdk1.8.0_181 /usr/lib/jvm/java-8-oracle`,这里的`java-8-oracle`是链接名,可根据个人喜好更改。 3. **配置环境变量**:为了让系统知道JDK的位置,我们需要更新`JAVA_HOME`环境...
安装完成后,开发者便可以在Linux环境中编写、编译和运行Java程序,享受JDK 8u261带来的最新特性和改进。 对于开发者来说,了解JDK的版本更新至关重要,因为它们通常包括了重要的安全修复和性能提升。例如,JDK 8u...
- 解压文件:`unzip jdk-8u191-linux-x64.zip` - 移动到适当目录:`sudo mv jdk1.8.0_191 /usr/lib/jvm/` - 更新系统路径:在`~/.bashrc`或`~/.bash_profile`中添加`export JAVA_HOME=/usr/lib/jvm/jdk1.8.0_191`...
在Java开发中,JDK动态代理是一个非常重要的概念,它允许我们在运行时创建对已有接口的代理实现。Spring框架在很多场景下也利用了这一特性,例如AOP(面向切面编程)就是其中之一。"spring-demo16-JDK动态代理.zip...
标签"jdk"、"jdk-8"、"jdk1.8"和"jdk-demo"分别代表了Java Development Kit,具体到Java 8版本,也就是1.8版本,以及与之相关的演示程序。JDK是Java程序员必备的工具集,它包括了编译器、调试器、文档生成工具以及...
总的来说,"jdk-8u211-windows-x64-demos.zip" 是一个宝贵的教育资源,适合那些想要提升Java编程技能,特别是对Java 8新特性感兴趣的开发者。通过研究这些示例代码,不仅可以掌握理论知识,还能获得实践经验,从而更...
Java 6是一个重要的Java版本,它引入了许多新特性,例如改进的内存管理、新的编译器、JavaScript引擎(Rhino)集成以及Swing组件的增强等。 在标签中,我们看到了"jdk"、"linux"、"i586"、"x86"和"rpm"这些关键词,...
Java JDK 8是Java开发历史上一个重要的里程碑,它引入了许多创新特性和改进,极大地提升了开发效率和代码的可读性。其中,Stream API和Lambda表达式是两大核心新特性,它们为处理集合数据提供了全新的方式。 **...
对于更高级的开发者,他们可以深入研究JDK 8u151的新特性和改进,比如Lambda表达式、方法引用来提升代码的简洁性,新的Stream API以方便数据处理,以及对Java内存模型和垃圾收集的优化等。同时,通过阅读源代码,...
标题中的"jdk-8u261-windows-x64-demos.zip"表明这是一个针对Windows 64位系统的Java 8 Update 261版本的JDK,其中包含了演示示例代码。 Java 8是Java的一个重要版本,于2014年发布,引入了多个新特性,极大地提升...
Java JDK 动态代理是一种强大的特性,它允许我们在运行时创建代理类,这些代理类可以扩展或修饰已存在的接口实现。动态代理在很多场景下非常有用,比如日志记录、性能监控、事务管理等,这些功能可以在不修改原始...
java8 源码 dates-and-times-in-jdk1.8 在jdk1.8中使用最新的时间方法 从jdk1.8开始,Oracle重写了日期与时间的实现。虽然我们仍然可以使用过去的方法来实现,但是掌握最新的方法可以更高效的解决时间日期相关的问题...