zoukankan      html  css  js  c++  java
  • 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)元空间

    junit测试

    /**
     * 
     * @ClassName:JDK8_features
     * @Description:JDK8新特性
     * @author diandian.zhang
     * @date 2017年4月17日上午9:13:24
     */
    public class JDK8_features {
        
        public List<Integer> list = Lists.newArrayList(1,2,3,4,5,6,7,8,9,10);
        
        /**
         * 1.Lambda表达式
         */
        @Test
        public void testLambda(){
            list.forEach(System.out::println);
            list.forEach(e -> System.out.println("方式二:"+e));
        }
        
        /**
         * 2.Stream函数式操作流元素集合
         */
        @Test
        public void testStream(){
            List<Integer> nums = Lists.newArrayList(1,1,null,2,3,4,null,5,6,7,8,9,10);
            System.out.println("求和:"+nums
                    .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<T>,接口默认方法不必须实现default forEach方法)
         */
        @Test
        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( "静态方法引用 " + car.toString() );
            }
                 
            public void repair() {   
                System.out.println( "任意对象的方法引用 " + this.toString() );
            }
            
            public void follow( final Car car ) {
                System.out.println( "特定对象的方法引用 " + car.toString() );
            }
        }
        
        /**
         * 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( "America/Los_Angeles" ) );
                     
            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( "Duration in days: " + duration.toDays() );
            System.out.println( "Duration in hours: " + duration.toHours() );
        }
        
        /**
         * 8.新增base64加解密API
         */
        @Test
        public void testBase64(){
            final String text = "就是要测试加解密!!abjdkhdkuasu!!@@@@";
            String encoded = Base64.getEncoder()
                .encodeToString( text.getBytes( StandardCharsets.UTF_8 ) );
            System.out.println("加密后="+ encoded );
             
            final String decoded = new String( 
                Base64.getDecoder().decode( encoded ),
                StandardCharsets.UTF_8 );
            System.out.println( "解密后="+decoded );
        }
        
        /**
         * 9.数组并行(parallel)操作
         */
        @Test
        public void testParallel(){
            long[] arrayOfLong = new long [ 20000 ];        
            //1.给数组随机赋值
            Arrays.parallelSetAll( arrayOfLong, 
                index -> ThreadLocalRandom.current().nextInt( 1000000 ) );
            //2.打印出前10个元素
            Arrays.stream( arrayOfLong ).limit( 10 ).forEach( 
                i -> System.out.print( i + " " ) );
            System.out.println();
            //3.数组排序
            Arrays.parallelSort( arrayOfLong );     
            //4.打印排序后的前10个元素
            Arrays.stream( arrayOfLong ).limit( 10 ).forEach( 
                i -> System.out.print( i + " " ) );
            System.out.println();
        }
        
        /**
         * 10.JVM的PermGen空间被移除:取代它的是Metaspace(JEP 122)元空间
         */
        @Test
        public void testMetaspace(){
            //-XX:MetaspaceSize初始空间大小,达到该值就会触发垃圾收集进行类型卸载,同时GC会对该值进行调整
            //-XX:MaxMetaspaceSize最大空间,默认是没有限制
            //-XX:MinMetaspaceFreeRatio在GC之后,最小的Metaspace剩余空间容量的百分比,减少为分配空间所导致的垃圾收集
            //-XX:MaxMetaspaceFreeRatio在GC之后,最大的Metaspace剩余空间容量的百分比,减少为释放空间所导致的垃圾收集
        }
        
    }
    引用到的相关类:
    public interface JDK8Interface1 {
    
        //1.接口中可以定义静态方法了
        public static void staticMethod(){
            System.out.println("接口中的静态方法");
        }
        
        //2.使用default之后就可以定义普通方法的方法体了
        public default void defaultMethod(){
            System.out.println("接口中的默认方法");
        }
    }
    
    public interface JDK8Interface2 {
    
        //接口中可以定义静态方法了
        public static void staticMethod(){
            System.out.println("接口中的静态方法");
        }
        //使用default之后就可以定义普通方法的方法体了
        public default void defaultMethod(){
            System.out.println("接口中的默认方法");
        }
    }
    
    /**
     * 
     * @ClassName:RepeatingAnnotations
     * @Description:重复注解@Repeatable
     * @author diandian.zhang
     * @date 2017年3月31日下午3:48:13
     */
    public class RepeatingAnnotations {
        @Target( ElementType.TYPE )
        @Retention( RetentionPolicy.RUNTIME )
        public @interface Filters {
            Filter[] value();
        }
         
        @Target( ElementType.TYPE )
        @Retention( RetentionPolicy.RUNTIME )
        @Repeatable( Filters.class )
        public @interface Filter {
            String value();
            String value2();
        };
         
        @Filter( value="filter1",value2="111" )
        @Filter( value="filter2", value2="222")
        //@Filters({@Filter(  value="filter1",value2="111" ),@Filter(  value="filter2", value2="222")}).注意:JDK8之前:1.没有@Repeatable2.采用本行“注解容器”写法
        public interface Filterable {        
        }
             
        public static void main(String[] args) {
            //获取注解后遍历打印值
            for( Filter filter: Filterable.class.getAnnotationsByType( Filter.class ) ) {
                System.out.println( filter.value() +filter.value2());
            }
        }
    }
    
    /**
     * 
     * @ClassName:Annotations
     * @Description:新增类型注解:ElementType.TYPE_USE 和ElementType.TYPE_PARAMETER(在Target上)
     * @author diandian.zhang
     * @date 2017年3月31日下午4:39:57
     */
    public class Annotations {
        @Retention( RetentionPolicy.RUNTIME )
        @Target( { ElementType.TYPE_USE, ElementType.TYPE_PARAMETER } )
        public @interface NonEmpty {        
        }
             
        public static class Holder< @NonEmpty T > extends @NonEmpty Object {
            public void method() throws @NonEmpty Exception {           
            }
        }
             
        public static void main(String[] args) {
            final Holder< String > holder = new @NonEmpty Holder< String >();       
            @NonEmpty Collection< @NonEmpty String > strings = new ArrayList<>();       
        }
    }

    摘自,https://www.cnblogs.com/dennyzhangdd/p/6722445.html

  • 相关阅读:
    linux 免交互状态下修改用户密码
    Sqlmap基础(一)
    cmd命令行指定系统延迟关机时间
    Shell 是个什么玩意
    Linux Shell脚本入门:tee命令
    shell脚本 -d 是目录文件,那么-e,-f等说明
    修改linux终端命令行颜色
    Linux 动画显示
    OpenVAS漏洞扫描基础教程之OpenVAS概述及安装及配置OpenVAS服务
    Curl命令使用
  • 原文地址:https://www.cnblogs.com/springcloud/p/8372471.html
Copyright © 2011-2022 走看看