JDK11 is coming!

写在前面的话

对于我来说最熟悉的应该是JDK8,对于9和10还没有太了解的时候,11都已经正式发布好久了,JDK的更新速度有点承受不住,幸好11是长期支持的版本,想必也会普及,提前尝鲜,一起学习。

1.JDK11

本次发布的Java 11和2017年9月份发布的Java 9以及 2018年3月份发布的Java 10相比,其最大的区别就是:在长期支持(Long-Term-Support)方面,Oracle表示会对Java 11提供大力支持,这一支持将会持续至2026年9月。这是据 Java 8 以后支持的首个长期版本 JDK11下载地址
从中可以看出,在Java 11之前,Java 9和Java 10是不提供长期支持的,而上一个提供长期支持的版本是Java 8,其将会支持到2025年3月

2.本地变量类型推断

局部变量类型推断,有点像JS,局部变量类型推断就是左边的类型直接使用 var 定义,而不用写具体的类型,编译器能根据右边的表达式自动推断类型,如下:

	var javaversion="JDK11";                 (等同于   String  javaversion="JDK11";)
 	System.out.println(javaversion);
 	结果:JDK11

3.字符串加强

Java 11 增加了一系列的字符串处理方法。

  1. 判断字符串是否为空白:isBlank()
	public boolean isBlank() {
        return indexOfNonWhitespace() == length();
    }	
  1. 去除首尾空格:strip() 去除首部空格:String.stripLeading() 去除尾部空格: String.stripTrailing()
	public String strip() {
        String ret = isLatin1() ? StringLatin1.strip(value)
                                : StringUTF16.strip(value);
        return ret == null ? this : ret;
    }
  1. 复制字符串:repeat(int count)
	public String repeat(int count) {
        if (count < 0) {
            throw new IllegalArgumentException("count is negative: " + count);
        }
        if (count == 1) {
            return this;
        }
        final int len = value.length;
        if (len == 0 || count == 0) {
            return "";
        }
        if (len == 1) {
            final byte[] single = new byte[count];
            Arrays.fill(single, value[0]);
            return new String(single, coder);
        }
        if (Integer.MAX_VALUE / count < len) {
            throw new OutOfMemoryError("Repeating " + len + " bytes String " + count +
                    " times will produce a String exceeding maximum size.");
        }
        final int limit = len * count;
        final byte[] multiple = new byte[limit];
        System.arraycopy(value, 0, multiple, 0, len);
        int copied = len;
        for (; copied < limit - copied; copied <<= 1) {
            System.arraycopy(multiple, 0, multiple, copied, copied);
        }
        System.arraycopy(multiple, 0, multiple, copied, limit - copied);
        return new String(multiple, coder);
    }
  1. 行数:lines()
	public Stream<String> lines() {
        return isLatin1() ? StringLatin1.lines(value)
                          : StringUTF16.lines(value);
    }
    
	var javaversion="JDK11\njava\n".lines().count();
    System.out.print(javasion);
    结果:2

4.集合加强

自 Java 9 开始,Jdk 里面为集合(List/ Set/ Map)都添加了 of 和 copyOf 方法,它们两个都用来创建不可变的集合,来看下它们的使用和区别。
示例1

		var list = List.of("Java", "jdk", "11");
        var copylist = List.copyOf(list);
        System.out.println(list == copylist ); 
        结果:true

示例2

		var listnew = new ArrayList<String>();
        var copylistnew = List.copyOf(list);
        System.out.println(listnew == copylistnew); 
        结果:false

通过分析源码:

static <E> List<E> of(E... elements) {
  switch (elements.length) { // implicit null check of elements
    case 0:
        return ImmutableCollections.emptyList();
    case 1:
        return new ImmutableCollections.List12<>(elements[0]);
    case 2:
        return new ImmutableCollections.List12<>(elements[0], elements[1]);
    default:
        return new ImmutableCollections.ListN<>(elements);
  }
}
static <E> List<E> copyOf(Collection<? extends E> coll) {
    return ImmutableCollections.listCopy(coll);
}
static <E> List<E> listCopy(Collection<? extends E> coll) {
    if (coll instanceof AbstractImmutableList && coll.getClass() != SubList.class) {
        return (List<E>)coll;
    } else {
        return (List<E>)List.of(coll.toArray());
    }
}

可以看出 copyOf 方法会先判断来源集合是不是 AbstractImmutableList 类型的,如果是,就直接返回,如果不是,则调用 of 创建一个新的集合。

示例2因为用的 new 创建的集合,不属于不可变 AbstractImmutableList 类的子类,所以 copyOf 方法又创建了一个新的实例,所以为false.

注意:使用of和copyOf创建的集合为不可变集合,不能进行添加、删除、替换、排序等操作,不然会报 java.lang.UnsupportedOperationException 异常。

上面演示了 List 的 of 和 copyOf 方法,Set 和 Map 接口都有。

5.Stream加强

Stream 是 Java 8 中的新特性。

  1. 增加单个参数构造方法,可为null:
	Stream.ofNullable(null).count(); 
	结果:0
  1. 增加 takeWhile 和 dropWhile 方法:
	Stream.of(1, 2, 3, 2, 1).takeWhile(n -> n < 3).collect(Collectors.toList()); 
	结果:[1,2]
	//从开始计算,当 n < 3 时就截止。
	Stream.of(1, 2, 3, 2, 1).dropWhile(n -> n < 3).collect(Collectors.toList());
	结果:[3,2,1]
	//这个和上面的相反,一旦 n < 3 不成立就开始计算。
  1. iterate重载:
	//这个 iterate 方法的新重载方法,可以让你提供一个 Predicate (判断条件)来指定什么时候结束迭代。
	public class Iterate11 {
    public static void main(String[] args) {
        // 这构造的是无限流 JDK8开始
        Stream.iterate(0, (x) -> x + 1);
        // 这构造的是小于10就结束的流 JDK9开始
        Stream.iterate(0, x -> x < 10, x -> x + 1);
    }
}

6.Optional 加强

Opthonal 也增加了几个非常酷的方法,现在可以很方便的将一个 Optional 转换成一个 Stream, 或者当一个空 Optional 时给它一个替代的。

	Optional.of("java11").orElseThrow(); 
	结果: javastack
	Optional.of("java11").stream().count(); 
	结果: 1
	Optional.ofNullable(null).or(() -> Optional.of("java11")).get(); 
	结果: javastack

7.InputStream 加强

InputStream 终于有了一个非常有用的方法:transferTo,可以用来将数据直接传输到 OutputStream,这是在处理原始数据流时非常常见的一种用法,如下示例(Exception未处理)。

	var classLoader = ClassLoader.getSystemClassLoader();
	var java11= classLoader.getResourceAsStream("java11.txt");
	var jdk11 = File.createTempFile("jdk11", "txt");
	try (var outputStream = new FileOutputStream(javastack)) {
    inputStream.transferTo(outputStream);
	}

8.HTTP Client API

这是 Java 9 开始引入的一个处理 HTTP 请求的的孵化 HTTP Client API,该 API 支持同步和异步,而在 Java 11 中已经为正式可用状态,可以在 java.net 包中找到这个 API。

var request = HttpRequest.newBuilder().uri(URI.create("https://javastack.cn")).GET().build();
var client = HttpClient.newHttpClient();
// 同步
HttpResponse<String> response = client.send(request, HttpResponse.BodyHandlers.ofString());
System.out.println(response.body());
// 异步
client.sendAsync(request, HttpResponse.BodyHandlers.ofString()).thenApply(HttpResponse::body)
.thenAccept(System.out::println);
//上面的 .GET() 可以省略,默认请求方式为 Get!

9.一个命令编译运行源代码

请看代码:

	// 编译
	javac Javastack.java
	// 运行
	java Javastack
	//在我们的认知里面,要运行一个 Java 源代码必须先编译,再运行,两步执行动作。
	//而在未来的 Java 11 版本中,通过一个 java 命令就直接搞定了,如以下所示。
	java Javastack.java

10.17个JEP(JDK Enhancement Proposals,JDK 增强提案)

181:基于嵌套的访问控制(Nest-Based Access Control)
309:动态类文件常量(Dynamic Class-File Constants)
315: 改进 Aarch64 内在函数(Improve Aarch64 Intrinsics)
318:Epsilon:无操作垃圾收集器(Epsilon: A No-Op Garbage Collector)
320:移除Java EE和CORBA模块(Remove the Java EE and CORBA Modules)
321:HTTP客户端(标准)
323:用于 Lambda 参数的局部变量语法(Local-Variable Syntax for Lambda Parameters)
324:Curve25519 和 Curve448 算法的密钥协议(Key Agreement with Curve25519 and Curve448)
327:Unicode 10
328:Flight Recorder
329:ChaCha20 和 Poly1305 加密算法(ChaCha20 and Poly1305 Cryptographic Algorithms)
330:启动单文件源代码程序(Launch Single-File Source-Code Programs)
331:低开销堆分析(Low-Overhead Heap Profiling)
332:传输层安全性(TLS)1.3
333:ZGC:可扩展的低延迟垃圾收集器(实验性)
335:弃用Nashorn JavaScript引擎
336:弃用 Pack200 工具和 API(Deprecate the Pack200 Tools and API)
JDK 详情

如果文章内容有什么问题,或者哪里出错,请及时与我联系。欢迎一起交流。

相关链接

JDK 11 安装指南
https://docs.oracle.com/en/java/javase/11/install/overview-jdk-installation.html#GU-98B9-1FD0B48C346A
JDK 11 发布说明
https://www.oracle.com/technetwork/java/javase/11u-relnotes-5093844.html
JDK 11 官方文档
https://docs.oracle.com/en/java/javase/11/
JDK 11 新特性
https://www.oracle.com/technetwork/java/javase/11-relnote-issues-5012449.html#NewFeature
Java 11 简介
https://blogs.oracle.com/java-platform-group/introducing-java-se-11
Readme
https://www.oracle.com/technetwork/java/javase/documentation/jdk11-readme-5097204.html

文件与目录操作 在Linux系统中 (1)创建一个文件,文件名为name.txt (2)向文件name.txt输入内容:echo ”dead is coming!“ > name.txt ,查看文件内容。 (3)创建一个info_elec_01目录 (4) 创建一个./java/jdk/jre目录 (5)在~目录下创建多个文件,文件名为name0.txt name1.txt name3.txt ... name20.txt (6)修改目录权限,创建一个目录~/permission_denied将他的权限改为111,然后是否还能执行ls -l 命令查下 (7) 将 name0.txt文件移动到新建立的info_elec_01目录下,同时实现将所有name1.txt name3.txt ... name20.txt文件移动到info_elec_01目录下。 (8)通过mv命令,将上面创建的文件name.txt 改名为hello.txt (9)用重定向将hello.txt文件内容清空 (10)用printf命令输入你的姓名全拼到hello.txt (11)用cp复制hello.txt到info_elec_02/name目录下 权限操作 1、新建一个文件 class.txt 输入三位同学 hanmeimei ,查看文件权限 2、grep hanmeimei 3、去掉r权限 看能grep hanmeimei 4、写入lilei到文件 class.txt 5、去掉w 看文件中还能不能添加 lihua内容 6、添加上执行x权限,看文件颜色 7、-- 去掉其他用户的r权限 8、用数字修改用户的权限rw- 用户组的权限rwx 其他用户权限 r-- 9、用字符修改用户权限+x 用户组 -w 其他用户 +w 10、修改class.txt 的用户及组 为 root:root 11、显示class.txt 最终的权限及详细信息 12、尝试用nano编辑器,输入三位同学名字,并且保存,退出。 13、显示class.txt 的内容
10-11
本系统旨在构建一套面向高等院校的综合性教务管理平台,涵盖学生、教师及教务处三个核心角色的业务需求。系统设计着重于实现教学流程的规范化与数据处理的自动化,以提升日常教学管理工作的效率与准确性。 在面向学生的功能模块中,系统提供了课程选修服务,学生可依据培养方案选择相应课程,并生成个人专属的课表。成绩查询功能支持学生查阅个人各科目成绩,同时系统可自动计算并展示该课程的全班最高分、平均分、最低分以及学生在班级内的成绩排名。 教师端功能主要围绕课程与成绩管理展开。教师可发起课程设置申请,提交包括课程编码、课程名称、学分学时、课程概述在内的新课程信息,亦可对已开设课程的信息进行更新或撤销。在课程管理方面,教师具备录入所授课程期末考试成绩的权限,并可导出选修该课程的学生名单。 教务处作为管理中枢,拥有课程审批与教学统筹两大核心职能。课程设置审批模块负责处理教师提交的课程申请,管理员可根据教学计划与资源情况进行审核批复。教学安排模块则负责全局管控,包括管理所有学生的选课最终结果、生成包含学号、姓名、课程及成绩的正式成绩单,并能基于选课与成绩数据,统计各门课程的实际选课人数、最高分、最低分、平均分以及成绩合格的学生数量。 资源来源于网络分享,仅用于学习交流使用,请勿用于商业,如有侵权请联系我删除!
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值