Java8设计的三个编程概念
流处理
流是一系列数据项,一次只生成一项。程序可以从输入流中一个一个读取数据项,然后以同样的方式将数据项写入输出流。一个程序的输出流很可能是另一个程序的输入流。
Java8在java.util.stream中添加了一个Stream API。Stream<T>就是一系列T类型的项目,其相当于迭代器一般,形成复杂的Stream操作流水线进行并行工作,而并非传统的一次只处理一个项目了。
用行为参数化把代码传递给方法
在Java8之前,我们无法将方法作为参数传递给另一个方法,最好的方法也只能是创建一个Comparator对象并实现它的compare方法来完成排序操作,虽然能实现重排序的功能,但对于"重用现有行为"的思想体现的并不是特别明显,同样代码也显得较为啰嗦。Java8增加了把代码作为参数的形式传递给另一个方法的能力,我们把这一概念称为行为参数化。如下图所示。
java8之前:
public class Operation{
public static void main(String[] args) {
User user01 = new User("bca", 11);
User user02 = new User("acb", 20);
List<User> users = Arrays.asList(user01,user02);
System.out.println(users); //[User [name=bca, age=11], User [name=acb, age=20]]
Collections.sort(users,new Comparator<User>() {
@Override
public int compare(User o1, User o2) {
return o1.getName().compareTo(o2.getName());
}
});
System.out.println(users); //[User [name=acb, age=20], User [name=bca, age=11]]
}
}
class User{
private String name;
private Integer age;
public User(String name, Integer age) {
super();
this.name = name;
this.age = age;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Integer getAge() {
return age;
}
public void setAge(Integer age) {
this.age = age;
}
@Override
public String toString() {
return "User [name=" + name + ", age=" + age + "]";
}
}
java8之后:
public class Operation{
public static void main(String[] args) {
...
users.sort(Comparator.comparing(User::getName));
...
}
}
class User{
private String name;
private Integer age;
...
}
并行和共享的可变数据
源自于流处理,在流处理中提过在Stream流水线中的并行处理,透明地把输入的不相关部分拿到几个CPU核上去分别来执行Stream操作的流水线——"几乎免费的并行",它可以同时在不同的输入上安全地执行,这也意味着所写的代码无法访问共享的可变数据来参与内部动作后进行修改操作,即非final局部变量不可修改行为。
>>> Java8-11新特性总结(一)
>>> Java8-11新特性总结(三)