JDK各个版本比较 JDK5~JDK9

JDK5

  1. 自动装箱与拆箱:
  2. 枚举
  3. 静态导入,如:import staticjava.lang.System.out
  4. 可变参数(Varargs)
  5. 内省(Introspector),主要用于操做JavaBean中的属性,经过getXxx/setXxx。通常的作法是经过类Introspector来获取某个对象的BeanInfo信息,而后经过BeanInfo来获取属性的描述器(PropertyDescriptor),经过这个属性描述器就能够获取某个属性对应的getter/setter方法,而后咱们就能够经过反射机制来调用这些方法。
  6. 泛型(Generic)(包括通配类型/边界类型等)
  7. For-Each循环
  8. 注解
  9. 协变返回类型:实际返回类型能够是要求的返回类型的一个子类型

 

JDK6

  1. AWT新增长了两个类:Desktop和SystemTray,其中前者用来经过系统默认程序来执行一个操做,如使用默认浏览器浏览指定的URL,用默认邮件客户端给指定的邮箱发邮件,用默认应用程序打开或编辑文件(好比,用记事本打开以txt为后缀名的文件),用系统默认的打印机打印文档等。后者能够用来在系统托盘区建立一个托盘程序。(开发中基本没用过)
  2. 使用JAXB2来实现对象与XML之间的映射,能够将一个Java对象转变成为XML格式,反之亦然
  3. StAX,一种利用拉模式解析(pull-parsing)XML文档的API。相似于SAX,也基于事件驱动模型。之因此将StAX加入到JAXP家族,是由于JDK6中的JAXB2和JAX-WS 2.0中都会用StAX。
  4. 使用Compiler API,动态编译Java源文件,如JSP编译引擎就是动态的,因此修改后无需重启服务器。(刚知道是从这里开始能够动态编译的)
  5. 轻量级Http Server API,据此能够构建本身的嵌入式HttpServer,它支持Http和Https协议。
  6. 插入式注解处理API(PluggableAnnotation Processing API)
  7. 提供了Console类用以开发控制台程序,位于java.io包中。据此可方便与Windows下的cmd或Linux下的Terminal等交互。
  8. 对脚本语言的支持如: ruby,groovy, javascript
  9. Common Annotations,原是J2EE 5.0规范的一部分,如今把它的一部分放到了J2SE 6.0中
  10. 嵌入式数据库 Derby

 

JDK7

  1. 对Java集合(Collections)的加强支持,可直接采用[]、{}的形式存入对象,采用[]的形式按照索引、键值来获取集合中的对象。
    List<String>list=[“item1”,”item2”];//存 Stringitem=list[0];//直接取 Set<String>set={“item1”,”item2”,”item3”};//存 Map<String,Integer> map={“key1”:1,”key2”:2};//存 Intvalue=map[“key1”];//取
  2. 在Switch中可用String
  3. 数值可加下划线用做分隔符(编译时自动被忽略)
  4. 支持二进制数字,如:int binary= 0b1001_1001;
  5. 简化了可变参数方法的调用
  6. 调用泛型类的构造方法时,能够省去泛型参数,编译器会自动判断。
  7. Boolean类型反转,空指针安全,参与位运算
  8. char类型的equals方法:
    boolean Character.equalsIgnoreCase(char ch1, char ch2) 
  9. 安全的加减乘除:
    Math.safeToInt(longv); Math.safeNegate(int v); Math.safeSubtract(long v1, int v2); Math.safeMultiply(int v1, int v2)…… 
  10. Map集合支持并发请求,注HashTable是线程安全的,Map是非线程安全的。但此处更新使得其也支持并发。另外,Map对象可这样定义:
    Map map = {name:”xxx”,age:18};

 

JDK8

  1. 接口的默认方法:即接口中能够声明一个非抽象的方法作为默认的实现,但只能声明一个,且在方法的返回类型前要加上“default”关键字。
  2. Lambda 表达式:是对匿名比较器的简化,如:
    Collections.sort(names,(String a, String b) -> { returnb.compareTo(a);}); //对于函数体只有一行代码的,你能够去掉大括号{}以及return关键字。如: Collections.sort(names,(String a, String b) -> b.compareTo(a)); Collections.sort(names, (a, b) -> b.compareTo(a));
  3. 函数式接口:是指仅仅只包含一个抽象方法的接口,要加@FunctionalInterface注解
  4. 使用 :: 关键字来传递方法或者构造函数引用
  5. 多重注解
  6. 还增长了不少与函数式接口相似的接口以及与Map相关的API等……

 

JDK9

    1. Java 平台级模块系统
      当启动一个模块化应用时, JVM 会验证是否全部的模块都能使用,这基于 requires 语句——比脆弱的类路径迈进了一大步。模块容许你更好地强制结构化封装你的应用并明确依赖。
    2. Linking
      当你使用具备显式依赖关系的模块和模块化的 JDK 时,新的可能性出现了。你的应用程序模块如今将声明其对其余应用程序模块的依赖以及对其所使用的 JDK 模块的依赖。为何不使用这些信息建立一个最小的运行时环境,其中只包含运行应用程序所需的那些模块呢? 这能够经过 Java 9 中的新的 jlink 工具实现。你能够建立针对应用程序进行优化的最小运行时映像而不须要使用彻底加载 JDK 安装版本。
    3. JShell : 交互式 Java REPL
      许多语言已经具备交互式编程环境,Java 如今加入了这个俱乐部。您能够从控制台启动 jshell ,并直接启动输入和执行 Java 代码。 jshell 的即时反馈使它成为探索 API 和尝试语言特性的好工具。
    4. 改进的 Javadoc
      Javadoc 如今支持在 API 文档中的进行搜索。另外,Javadoc 的输出如今符合兼容 HTML5 标准。此外,你会注意到,每一个 Javadoc 页面都包含有关 JDK 模块类或接口来源的信息。
    5. 集合工厂方法
      一般,您但愿在代码中建立一个集合(例如,List 或 Set ),并直接用一些元素填充它。 实例化集合,几个 “add” 调用,使得代码重复。 Java 9,添加了几种集合工厂方法:
      Set<Integer> ints = Set.of(1,2,3); List<String> strings = List.of("first","second");

      除了更短和更好阅读以外,这些方法也能够避免您选择特定的集合实现。 事实上,从工厂方法返回已放入数个元素的集合实现是高度优化的。这是可能的,由于它们是不可变的:在建立后,继续添加元素到这些集合会致使 “UnsupportedOperationException” 。javascript

    6. 改进的 Stream API
      长期以来,Stream API 都是 Java 标准库最好的改进之一。经过这套 API 能够在集合上创建用于转换的申明管道。在 Java 9 中它会变得更好。Stream 接口中添加了 4 个新的方法:dropWhile, takeWhile, ofNullable。还有个 iterate 方法的新重载方法,可让你提供一个 Predicate (判断条件)来指定何时结束迭代:
      IntStream.iterate(1, i -> i < 100, i -> i + 1).forEach(System.out::println);
      第二个参数是一个 Lambda,它会在当前 IntStream 中的元素到达 100 的时候返回 true。所以这个简单的示例是向控制台打印 1 到 99。
      除了对 Stream 自己的扩展,Optional 和 Stream 之间的结合也获得了改进。如今能够经过 Optional 的新方法 stream 将一个 Optional 对象转换为一个(多是空的) Stream 对象:
      Stream s = Optional.of(1).stream();
      在组合复杂的 Stream 管道时,将 Optional 转换为 Stream 很是有用。
    7. 私有接口方法
      使用 Java 9,您能够向接口添加私有辅助方法来解决此问题:
      public interface MyInterface { void normalInterfaceMethod(); default void interfaceMethodWithDefault() { init(); } default void anotherDefaultMethod() { init(); } //This method is not part of the public API exposed by MyInterface private void init() { System.out.println("Initializing"); } }

      若是您使用默认方法开发 API ,那么私有接口方法可能有助于构建其实现。java

    8. HTTP/2
      Java 9 中有新的方式来处理 HTTP 调用。这个迟到的特性用于代替老旧的 HttpURLConnection API,并提供对 WebSocket 和 HTTP/2 的支持。注意:新的 HttpClient API 在 Java 9 中以所谓的孵化器模块交付。也就是说,这套 API 不能保证 100% 完成。不过你能够在 Java 9 中开始使用这套 API:
      HttpClient client = HttpClient.newHttpClient(); HttpRequest req = HttpRequest.newBuilder(URI.create("http://www.google.com")).header("User-Agent","Java").GET().build(); HttpResponse<String> resp = client.send(req, tpResponse.BodyHandler.asString()); HttpResponse<String> resp = client.send(req,HttpResponse.BodyHandler.asString());

      除了这个简单的请求/响应模型以外,HttpClient 还提供了新的 API 来处理 HTTP/2 的特性,好比流和服务端推送。git

    9. 多版本兼容 JAR
      咱们最后要来着重介绍的这个特性对于库的维护者而言是个特别好的消息。当一个新版本的 Java 出现的时候,你的库用户要花费数年时间才会切换到这个新的版本。这就意味着库得去向后兼容你想要支持的最老的 Java 版本 (许多状况下就是 Java 6 或者 7)。这实际上意味着将来的很长一段时间,你都不能在库中运用 Java 9 所提供的新特性。幸运的是,多版本兼容 JAR 功能能让你建立仅在特定版本的 Java 环境中运行库程序时选择使用的 class 版本
相关文章
相关标签/搜索