112.java基础21(java11新特性回顾)

1.JShell

最低java9 jdk; 并配置环境变量
cmd 中启动 jshell 进入 命令行,可以直接执行java代码,不需要编译
/help  帮助界面

2.局部变量类型推断:

List<interger> list = new ArrayList<>();  
list.add("abc");  // 不能添加,转化不了Integer
var a = "abc"; == String a = "abc";

var b = new StringBuffer("123");
var a = new ArrayList<Integer>();

System.out.println(a.getClass()); // class java.util.ArrayList

var n; 无法推断类型,不能这样使用,同时类的属性的数据类型不可以使用var
    
Thread t = new Thread(()->Systeom.out.println(Thread.currentThread().getName()));
t.start();

有参数的lambda表达式使用
函数式接口:
	Consumer<T>: 消费型函数式接口
        public void accept(T t):
    Counsumer<String> consumer = t -> Systeom.out.println(t.toUpperCase());
	Counsumer<String> consumer = (var t) -> Systeom.out.println(t.toUpperCase());
	
 	Counsumer<String> consumer = (@Nullnull/Deprecated var t) -> Systeom.out.println(t.toUpperCase()); // 可以给变量加注解,没有用var声明不能加注解

3.集合中的一些增强的API:

package com.atguigu.java11;
import java.time.LocalDate;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.Set;
import java.util.stream.Stream;
import org.junit.Test;
public class APITest {
	// 集合中的一些增强的API
	@Test
	public void test3() {
		LocalDate localDate = LocalDate.of(2019, 1, 21);
		// 在添加重复元素时, 不是无法添加, 而是抛出异常
		//Set<Integer> set = Set.of(100, 50, 20, 30, 10, 8, 100, 8);
		Set<Integer> set = Set.of(100, 50, 20, 30, 10, 8);
		System.out.println(set.getClass());
		Stream<Integer> stream = Stream.of(50, 20, 30, 70);
	}
	@Test
	public void test2() {
		//快速创建数组
		int[] arr = {1, 9, 3, 2, 8};
		// 快速把数据变成集合的方法
		List<String> list1 = Arrays.asList("aa", "yyy", "zzz", "123");
		//list1.add("ppp"); // 是一个不可以添加元素的集合
		// 集合的创建可以使用更简单的方式
		List<String> list2 = List.of("aa", "bbb", "cc", "DD");
		System.out.println(list2);
		//list2.add("yyy"); // 不可以添加元素
		System.out.println(list2);
	}
	@Test
	public void test1() {
		List<String> list = new ArrayList<>();
		list.add("aa");
		list.add("bbb");
		list.add("cc");
		list.add("DD");
		System.out.println(list);
	}
}

4.Stream 加强:

package com.atguigu.java11;

import java.util.stream.Stream;

import org.junit.Test;

/**
 * 流的处理
 * 1) 创建流
 * 2) 中间操作
 * 3) 终止操作
 */

public class StreamTest {
	
	@Test
	public void test3() {
		// 流的迭代, 创建流
		Stream<Integer> stream1 = Stream.iterate(1, t -> (2 * t) + 1);
		stream1.limit(10).forEach(System.out::println);
		
		System.out.println("*************************");
		// 有限的迭代
		Stream<Integer> stream2 = Stream.iterate(1, t -> t < 1000, t -> (2 * t) + 1);
		stream2.forEach(System.out::println);
	}
	
	@Test
	public void test2() {
		Stream<Integer> stream1 = Stream.of(3, 9, 20, 22, 40, 7);
		// 新方法, takeWhile, dropWhile
		// 从流中一直获取判定器为真的元素, 一旦遇到元素为假, 就终止处理.
		Stream<Integer> stream2 = stream1.takeWhile(t -> t % 2 != 0);
		stream2.forEach(System.out::println); // 输出 3,9
		System.out.println("**********************");
		stream1 = Stream.of(3, 9, 20, 22, 40, 7);
		Stream<Integer> stream3 = stream1.dropWhile(t -> t % 2 != 0);
		stream3.forEach(System.out::println); //输出 20,22,40,7
		
	}
	
	@Test
	public void test1() {
		Stream<Integer> stream1 = Stream.of(3, 9, 20, 22, 40);
		//stream1.forEach(t -> System.out.println(t));
		stream1.forEach(System.out::println);
		
		System.out.println("***********************************");
		
		Stream<Object> stream2 = Stream.of(); // 流中没有数据
		stream2.forEach(System.out::println);
		
		System.out.println("***********************************");
		
		// 传入null会被解析为是一个数组对象, 会进一步访问它的长度信息
		//Stream<Object> stream3 = Stream.of(null);
		//stream3.forEach(System.out::println);
		
		// 可以传入 一个null来创建流对象
		Stream<Object> stream3 = Stream.ofNullable(null);
		stream3.forEach(System.out::println);
	}
}

5.string 字符串新增方法:

package com.atguigu.java11;

import static org.junit.Assert.*;

import java.io.FileInputStream;

import org.junit.Test;

public class StringTest {
	
	@Test
	public void testName3() throws Exception {
		FileInputStream fis = new FileInputStream("src/com/atguigu/java11/StringTest.java");
		byte[] buffer = new byte[fis.available()];// fis.available() 整个文件的字符数
		fis.read(buffer);
		fis.close();
		String string = new String(buffer);
		string.lines().forEach(System.out::println); // string.lines()是stream流
	}
	
	@Test
	public void testName2() throws Exception {
		String string = "Java";
		String string2 = string.repeat(5); //复制五次
		System.out.println(string2); // JavaJavaJavaJavaJava
	}

	@Test
	public void testName() throws Exception {
		String string = " \t  \r\n ";
		System.out.println(string.isBlank()); // 判断字符串中的字符是否都是空白
		
		System.out.println("**************************");
		
		string = " \t  \r\n abc \t ";
		String string2 = string.strip(); // 去重字符串首尾的空白, 包括英文和其他所有语言中的空白字符
		System.out.println(string2);
		System.out.println(string2.length());
		
		String string3 = string.trim(); // 去重字符串首尾的空白字符, 只能去除码值小于等于32的空白字符
		System.out.println(string3);
		System.out.println(string3.length());
		
		System.out.println("**************************");
		String string4 = string.stripLeading(); // 去重字符串首部的空白
		System.out.println(string4);
		System.out.println(string4.length());
		
		String string5 = string.stripTrailing(); // 去重字符串尾部的空白
		System.out.println(string5);
		System.out.println(string5.length());
	}
}	

6.Optional 加强:

package com.atguigu.java11;

import static org.junit.Assert.*;
import java.util.Optional;
import org.junit.Test;

public class OptionalTest {
	@Test
	public void testName() throws Exception {
		// of方法中如果传入的参数是null, 会抛出空指针异常
		//Optional<String> optional = Optional.of(null);
		// ofNullable可以兼容空指针, 但是实际传入null后要小心
		Optional<Object> optional = Optional.ofNullable(null);
		Object object = optional.orElse("abc"); // 如果内部引用为空, 则返回参数中的引用, 否则返回内部引用: 打印abc
		System.out.println(object);
		
		Object object2 = optional.orElseThrow();
		System.out.println(object2);
	}
}

7.流自动文件复制:

package com.atguigu.java11;

import static org.junit.Assert.*;
import java.io.FileOutputStream;
import org.junit.Test;

public class InputStreamTest {
	@Test
	public void testName() throws Exception {
		var cl = this.getClass().getClassLoader();
		try (var is = cl.getResourceAsStream("file"); var os = new FileOutputStream("file2")) {
			is.transferTo(os); // 把输入流中的所有数据直接自动地复制到输出流中
		}
	}
}

8.HTTPClient:

package com.atguigu.java11;

import static org.junit.Assert.*;

import java.net.URI;
import java.net.http.HttpClient;
import java.net.http.HttpRequest;
import java.net.http.HttpResponse;
import java.net.http.HttpResponse.BodyHandler;
import java.net.http.HttpResponse.BodyHandlers;
import java.util.concurrent.CompletableFuture;

import org.junit.Test;

public class HTTPClientTest {
	
	@Test
	public void testName2() throws Exception {
		HttpClient client = HttpClient.newHttpClient();
		HttpRequest request = HttpRequest.newBuilder(URI.create("http://127.0.0.1:8080/test/")).build();
		BodyHandler<String> responseBodyHandler = BodyHandlers.ofString();
		CompletableFuture<HttpResponse<String>> sendAsync = client.sendAsync(request, responseBodyHandler);
		sendAsync.thenApply(t -> t.body()).thenAccept(System.out::println);
		//HttpResponse<String> response = sendAsync.get();
		//String body = response.body();
		//System.out.println(body);
		
	}
	
	@Test
	public void testName() throws Exception {
		HttpClient client = HttpClient.newHttpClient();
		HttpRequest request = HttpRequest.newBuilder(URI.create("http://127.0.0.1:8080/test/")).build();
		BodyHandler<String> responseBodyHandler = BodyHandlers.ofString();
		HttpResponse<String> response = client.send(request, responseBodyHandler);
		String body = response.body();
		System.out.println(body);
	}
}

9.增强java启动器:

增强java启动器支持运行单个java源代码文件的程序.

注意点 :
1)执行源文件中的第一个类, 第一个类必须包含主方法
2)并且不可以使用别源文件中的自定义类, 本文件中的自定义类是可以使用的.

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

10.新的Epsilon垃圾收集器:

package com.atguigu.java11;

import java.util.ArrayList;
import java.util.List;

class Garbage {
	
	private double d1 = 1;
	private double d2 = 2;
	
	// 这个方法是GC在清除本对象时, 会调用一次
	@Override
	public void finalize() {
		System.out.println(this + " collecting");
	}
}

public class EpsilonTest {
	
	// 执行: -XX:+UnlockExperimentalVMOptions -XX:+UseEpsilonGC
	public static void main(String[] args) {
		List<Garbage> list = new ArrayList<>();
		boolean flag = true;
		int count = 0;
		while (flag) {
			list.add(new Garbage());
			if (count++ == 500) {
				list.clear();  // 将前五百个设置为垃圾对象,等待gc回收,之后创建的将不再进行回收,这个时候会导致内存溢出
			}
		}
	}
}
主要用途如下 :
	性能测试(它可以帮助过滤掉GC引起的性能假象)
	内存压力测试(例如,知道测试用例 应该分配不超过1GB的内存, 我们可以使用-Xmx1g –XX:+UseEpsilonGC, 如果程序有问题, 则程序会崩溃)
	非常短的JOB任务(对象这种任务, 接受GC清理堆那都是浪费空间)
	VM接口测试
	Last-drop 延迟&吞吐改进

11.zgc:

这个东西还是实验性质的,暂时可以做测试使用

// linux 64位中可以使用
package com.atguigu.java11;
import java.util.ArrayList;
import java.util.List;
public class ZGCTest {
	//  执行: -XX:+UnlockExperimentalVMOptions -XX:+UseZGC
	public static void main(String[] args) {
		List<Garbage> list = new ArrayList<>();
		boolean flag = true;
		int count = 0;
		while (flag) {
			list.add(new Garbage());
			if (count++ % 500 == 0) {
				list.clear();
			}
			try {
				Thread.sleep(500);
			} catch (InterruptedException e) {
				e.printStackTrace();
			}
		}
	}
}

上一篇:数据分析 之 NumPy


下一篇:112.路径总和