Java 11 没有引入突破性的功能,但包含了许多你可能还没有听说过的宝石:
1. Lambda参数的类型推断
List<EnterpriseGradeType<With, Generics>> types = <font><i>/*...*/</i></font><font>; types.stream() </font><font><i>// this is fine, but we need @Nonnull on the type</i></font><font> .filter(type -> check(type)) </font><font><i>// in Java 10, we need to do this ~> ugh!</i></font><font> .filter((@Nonnull EnterpriseGradeType<With, Generics> type) -> check(type)) </font><font><i>// in Java 11, we can do this ~> better</i></font><font> .filter((@Nonnull <b>var</b> type) -> check(type)) 2. </font>
String :: lines
有多行字符串?想要对每一行做点什么吗?
<b>var</b> multiline = <font>"This/r/nis a/r/nmultiline/r/nstring"</font><font>; multiline.lines() </font><font><i>// we now have a `Stream<String>`</i></font><font> .map(line -> </font><font>"// "</font><font> + line) .forEach(System.out::println); </font><font><i>// OUTPUT:</i></font><font> </font><font><i>// This</i></font><font> </font><font><i>// is a</i></font><font> </font><font><i>// multiline</i></font><font> </font><font><i>// string</i></font><font> 3. </font>
使用'String :: strip'等来剥离空格
4. 用'String :: repeat'重复字符串
5. 使用'Path :: of'创建路径
Path tmp = Path.of(<font>"/home/nipa"</font><font>, </font><font>"tmp"</font><font>); Path codefx = Path.of(URI.create(</font><font>"http://codefx.org"</font><font>)); </font>
6. 使用'Files :: readString'和'Files :: writeString'读取和写入文件
String haiku = Files.readString(Path.of(<font>"haiku.txt"</font><font>)); String modified = modify(haiku); Files.writeString(Path.of(</font><font>"haiku-mod.txt"</font><font>), modified); </font>
7. 空读I / O使用'Reader :: nullReader
需要一个丢弃输入字节的 OutputStream吗?需要一个空的 InputStream?使用Reader和Writer但是什么也不做?Java 11让你满意:
InputStream input = InputStream.nullInputStream(); OutputStream output = OutputStream.nullOutputStream(); Reader reader = Reader.nullReader(); Writer writer = Writer.nullWriter();
8. 集合变成一个数组:Collection :: toArray
String[] strings_fun = list.toArray(String[]::<b>new</b>);
9. 使用Optional :: isEmpty表达不存在概念
<b>public</b> <b>boolean</b> needsToCompleteAddress(User user) { <b>return</b> getAddressRepository() .findAddressFor(user) .map(<b>this</b>::canonicalize) .filter(Address::isComplete) .isEmpty(); }
10. 使用谓词::not 表达 “不”
Stream.of(<font>"a"</font><font>, </font><font>"b"</font><font>, </font><font>""</font><font>, </font><font>"c"</font><font>) </font><font><i>// statically import `Predicate.not`</i></font><font> .filter(not(String::isBlank)) .forEach(System.out::println); </font>
11. 使用'Pattern :: asMatchPredicate'作为谓词的正则表达式
Pattern nonWordCharacter = Pattern.compile(<font>"//W"</font><font>); Stream.of(</font><font>"Metallica"</font><font>, </font><font>"Motörhead"</font><font>) .filter(nonWordCharacter. </font>
asMatchPredicate
()) .forEach(System.out::println);
asMatchPredicate是要求整个字符串匹配,而asPredicate 只需要字符串中出现过或有匹配的一段子串即可,要求不高。