本文共 4905 字,大约阅读时间需要 16 分钟。
JDK 11 是一个长期支持版本(LTS, Long-Term-Support
//java 11新特性一:String中新增的方法 @Test public void test1() { // isBlank():判断字符串是否为空白 System.out.println("\t \t \n".isBlank());//true// strip():去除首尾空白 System.out.println("----" + "\t ab \n \t".strip() + "----");//----ab---- System.out.println("----" + "\t ab \n \t".trim() + "----");//----ab----// stripTrailing():去除尾部空格 System.out.println("----" + " \t ab \n \t ".stripTrailing() + "----");//---- ab----// stripLeading():去除首部空格 System.out.println("----" + " \t ab \n \t ".stripLeading() + "----");//----ab //----// repeat(int count):复制字符串,count为复制次数 String str1 = "abc"; String str2 = str1.repeat(3); System.out.println(str2);//abcabcabc// lines().count():行数统计 String str3 = "ab \t c \nd\n"; long count = str3.lines().count(); System.out.println(count);//2 }
Optional 也增加了几个非常酷的方法,现在可以很方便的将一个 Optional 转换 成一个 Stream, 或者当一个空 Optional 时给它一个替代的
//java11新特性二:Optional新增的方法 @Test public void test2(){ //Optional.of(T t) : 创建一个 Optional 实例,t必须非空; var op = Optional.empty(); System.out.println(op.isPresent());//判断内部的value是否存在 System.out.println(op.isEmpty());//判断内部的value是否为空 op = Optional.of("abc"); //orElseThrow():value非空,返回value;否则抛异常NoSuchElementException var obj = op.orElseThrow(); System.out.println(obj); Optionalop1 = Optional.of("hello");// op = Optional.empty(); //or:value非空,返回对应的Optional;value为空,返回形参封装的Optional Optional
在var上添加注解的语法格式,在jdk10中是不能实现的。在JDK11中加入了这样 的语法
//java11新特性:局部变量类型推断的升级 @Test public void test3(){ //错误的形式: 必须要类型, 可以加上var// Consumercon1 = (@Deprecated t) -> System.out.println(t.toUpperCase()); // 正确的形式: // 使用var的好处是在使用lambda表达式时给参数加上注解。 Consumer con2 = (@Deprecated var t) -> System.out.println(t.toUpperCase()); }
//java11新特性四:HttpClient替换原的HttpURLConnection。 @Test public void test4(){ try { HttpClient client = HttpClient.newHttpClient(); HttpRequest request = HttpRequest.newBuilder(URI.create("http://127.0.0.1:8080/test/")).build(); HttpResponse.BodyHandlerresponseBodyHandler = HttpResponse.BodyHandlers.ofString(); HttpResponse response = client.send(request, responseBodyHandler); String body = response.body(); System.out.println(body); } catch (IOException e) { e.printStackTrace(); } catch (InterruptedException e) { e.printStackTrace(); } } @Test public void test5(){ HttpClient client = HttpClient.newHttpClient(); HttpRequest request = HttpRequest.newBuilder(URI.create("http://127.0.0.1:8080/test/")).build(); HttpResponse.BodyHandler responseBodyHandler = HttpResponse.BodyHandlers.ofString(); CompletableFuture > sendAsync = client.sendAsync(request, responseBodyHandler); sendAsync.thenApply(t -> t.body()).thenAccept(System.out::println); //HttpResponse response = sendAsync.get(); //String body = response.body(); //System.out.println(body); }
看下面的代码。
// 编译 javac Javastack.java // 运行 java Javastack
在我们的认知里面,要运行一个 Java 源代码必须先编译,再运行,两步执行动作。 而在未来的 Java 11 版本中,通过一个 java 命令就直接搞定了,如以下所示: java Javastack.java
一个命令编译运行源代码的注意点:废除Nashorn javascript引擎,在后续版本准备移除掉,有需要的 可以考虑使用GraalVM
优势:
ZGC的设计目标是:支持TB级内存容量,暂停时间低(<10ms),对整个 程序吞吐量的影响小于15%。 将来还可以扩展实现机制,以支持不少令人 兴奋的功能,例如多层堆(即热对象置于DRAM和冷对象置于NVMe闪存), 或压缩堆
转载地址:http://ttuki.baihongyu.com/