jdk各版本特性速记

来源:互联网 发布:煤化工行业前景知乎 编辑:程序博客网 时间:2024/06/05 08:17

jdk8

  • Lambda 表达式 − Lambda允许把函数作为一个方法的参数(函数作为参数传递进方法中。
package jdk8;public class LambdaPractice {    public static void main(String[] args) {        MathOperation addition = (int a, int b) -> a + b;        MathOperation subtraction = (a, b) -> a - b;        MathOperation multiplication = (int a, int b) -> {            return a * b;        };        MathOperation division = (int a, int b) -> a / b;        System.out.println("60 + 12 = " + operate(60, 12, addition));        System.out.println("60 - 12 = " + operate(60, 12, subtraction));        System.out.println("60 x 12 = " + operate(60, 12, multiplication));        System.out.println("60 / 12 = " + operate(60, 12, division));    }    private static int operate(int a, int b, MathOperation mathOperation) {        return mathOperation.operation(a, b);    }}@FunctionalInterfaceinterface MathOperation {    int operation(int a, int b);}
  • 方法引用−方法引用提供了非常有用的语法,可以直接引用已有Java类或对象(实例)的方法或构造器。与lambda联合使用,方法引用可以使语言的构造更紧凑简洁,减少冗余代码。
构造器引用:它的语法是Class::new静态方法引用:它的语法是Class::static_method特定类的任意对象的方法引用:它的语法是Class::method特定对象的方法引用:它的语法是instance::method
  • 默认方法 − 默认方法就是一个在接口里面有了一个实现的方法。
    默认方法就是接口可以有实现方法,而且不需要实现类去实现其方法。只需在方法名前面加个default关键字即可实现默认方法
package jdk8;public class DefaultAndStaticMethod implements A {    public static void main(String[] args) {        DefaultAndStaticMethod defaultAndStaticMethod = new DefaultAndStaticMethod();        // 调用默认方法        defaultAndStaticMethod.print();        //调用静态方法        A.born();        //调用继承的默认方法        defaultAndStaticMethod.inherit();    }    @Override    public void inherit() {        System.out.println("继承自A的方法");    }}interface A {    default void print() {        System.out.println("我是A默认方法");    }    default  void inherit() {        System.out.println("我是A需要被继承的方法");    }    static void born() {        System.out.println("我是A静态方法");    }}
  • Stream API −新添加的Stream API(java.util.stream) 把真正的函数式编程风格引入到Java中。

    增加了一些新的 IO/NIO 方法,使用这些方法可以从文件或者输入流中获取流(java.util.stream.Stream),通过对流的操作,可以简化文本行处理、目录遍历和文件查找。
    新增的 API 如下:
    BufferedReader.line(): 返回文本行的流 Stream
    File.lines(Path, Charset):返回文本行的流 Stream
    File.list(Path): 遍历当前目录下的文件和目录
    File.walk(Path, int, FileVisitOption): 遍历某一个目录下的所有文件和指定深度的子目录
    File.find(Path, int, BiPredicate, FileVisitOption… ): 查找相应的文件
    见http://blog.csdn.net/aloneload/article/details/78091860

  • Date Time API − 加强对日期与时间的处理。

java.time 中包含了所有关于时钟(Clock),本地日期(LocalDate)、本地时间(LocalTime)、本地日期时间(LocalDateTime)、时区(ZonedDateTime)和持续时间(Duration)的类

public class DateTimeApi {    public static void main(String[] args) throws InterruptedException {        test();    }    private static void test() throws InterruptedException {        // LocalDate        LocalDate localDate = LocalDate.of(2017, Month.OCTOBER, 1);// 2017-10-01        int year = localDate.getYear(); // 2017        Month month = localDate.getMonth(); // OCTOBER        int dom = localDate.getDayOfMonth(); // 1        DayOfWeek dow = localDate.getDayOfWeek(); // SUNDAY        boolean leap = localDate.isLeapYear(); // false (不是闰年)        // LocalTime        LocalTime time = LocalTime.of(14, 32); // 14:32        int hour = time.getHour(); // 14        int minute = time.getMinute(); // 32        time = time.withSecond(6); // 14:32:06        time = time.plusMinutes(3); // 20:35:06        // LocalDateTime        LocalDateTime localDateTime = LocalDateTime.now();        // of: 静态工厂方法,从组成部分中创建实例        // now: 静态工厂方法,用当前时间创建实例        // parse: 静态工厂方法,总字符串解析得到对象实例        // with: 返回一个部分状态改变了的时间日期对象拷贝        // plus: 返回一个时间增加了的、时间日期对象拷贝        // minus: 返回一个时间减少了的、时间日期对象拷贝        // at: 用当前时间日期对象组合另外一个,创建一个更大或更复杂的时间日期对象        // format: 提供格式化时间日期对象的能力        // Instance时刻        Instant start = Instant.now();        Thread.sleep(1001);        Instant end = Instant.now();        System.out.println("end-start=" + (end.compareTo(start)));        // Duration period 时间段 可作为参数进行日期时间的运算        Duration duration = Duration.of(1, ChronoUnit.HOURS);        Period period = Period.of(1, 2, 3);        System.out.println(duration + period.toString());        // 格式化        DateTimeFormatter dateTimeFormatter = DateTimeFormatter.ofPattern("yyyy/MM/dd");        LocalDate localDate2 = LocalDate.parse("2017/10/01", dateTimeFormatter);        String date = localDate2.format(dateTimeFormatter);        System.out.println();        // ZoneId        ZoneId zoneId = ZoneId.of("America/Caracas");        LocalDate date2 = localDate.now(zoneId);        System.out.println(date2);    }}
  • Optional 类 − Optional 类已经成为 Java 8 类库的一部分,用来解决空指针异常。

Optional将对象和null包装起来,使得null有迹可循

package jdk8;import java.util.Optional;public class OptionalTest {    public static void main(String[] args) {        test();    }    private static void test() {        Optional<String> optional = Optional.of("java8");        // Optional<String> optional2 = Optional.of(null); 报错        Optional<String> optional2 = Optional.ofNullable(null);        String name = optional2.orElse("default");        System.out.println("name:" + name);// 输出default        // 如果不包装,将得不到有用的信息        // optional2.get();// ava.util.NoSuchElementException: No value present        // orElseThrow与orElse方法类似,区别在于返回值。        // orElseThrow抛出由传入的lambda表达式/方法生成异常。        try {            optional2.orElseThrow(Exception::new);        } catch (Throwable ex) {            System.out.println(ex.getMessage());        }        // lambda表达式返回值会包装为Optional实例。        Optional<String> upperName = optional.map((value) -> value.toUpperCase());        // 如果满足返回Optional实例值,否则返回空Optional。        Optional<String> longName = optional2.filter((value) -> value.length() > 6);    }}
  • Nashorn, JavaScript 引擎 − Java 8提供了一个新的Nashorn
    javascript引擎,它允许我们在JVM上运行特定的javascript应用。
  • 新工具 − 新的编译工具,如:Nashorn引擎 jjs、 类依赖分析器jdeps。
jdeps LambdaPractice.class

这里写图片描述

jdk7

  • 在Switch中可用String
String s = "java8";        switch (s) {        case "java8":            System.out.println("java8");            break;        case "java7":            System.out.println("java7");            break;        default:            System.out.println("default");            break;        }
  • 数值可加下划线用作分隔符(编译时自动被忽略)
 int add=1_342_000;
  • 增强的try
    资源管理器自动调用资源的close()函数。和Python里的with语句差不多,再也不用担心忘关资源了
// try-with-resource        try (BufferedReader br = new BufferedReader(new FileReader("data/nio-data.txt"))) {            String line;            while((line=br.readLine())!=null) {            System.out.println(line);            }        } catch (IOException|NumberFormatException e) {//此处演示多个异常            e.printStackTrace();        }

另网传的对Java集合(Collections)的增强支持,可直接采用[]、{}的形式存入对象,采用[]的形式按照索引、键值来获取集合中的对象。此特性并不支持

jdk5

  • 自动装箱与拆箱
int a = 4;Integer b = 5;// 装箱 5-》integer  System.out.println(a + b);// 拆箱 //计算 int 的4+5
  • 枚举
    单例模式最好的实现
enum Version {    JDK8(8), JDK7(7);    private int attibute;    public int getAttibute() {        return this.attibute;    }    private Version(int attibute) {        this.attibute = attibute;    }//使用Version.JDK8.getAttibute();得到属性
  • 静态导入
import static java.lang.Math.*;
  • 可变参数
// 可变参数    private static int sum(int... intlist) {        int sum;        sum = 0;        for (int i = 0; i < intlist.length; i++) {            sum += intlist[i];        }        return sum;    }    //System.out.println(sum(1, 2, 3));    //System.out.println(sum(1, 2));
  • 内省,主要用于操作JavaBean中的属性,通过getXxx/setXxx。一般的做法是通过类Introspector来获取某个对象的BeanInfo信息,然后通过BeanInfo来获取属性的描述器(PropertyDescriptor),通过这个属性描述器就可以获取某个属性对应的getter/setter方法,然后我们就可以通过反射机制来调用这些方法。
People people = new People(1,"zhangsan");        BeanInfo beanInfo=Introspector.getBeanInfo(people.getClass());        PropertyDescriptor[] pds = beanInfo.getPropertyDescriptors();        for (PropertyDescriptor propertyDescriptor : pds) {            Object out2 = propertyDescriptor.getReadMethod().invoke(people);            System.out.println(out2);        }
  • 泛型(包括通配类型/边界类型等)
  • For-Each循环
  • 注解

GitHub:https://github.com/aloneload/JdkFeatures

原创粉丝点击