假设你有
class Entity {
final long id;
final String data;
public long getId() {
return id;
}
public String getData() {
return data;
}
Entity(long id, String data) {
this.id = id;
this.data = data;
}
}
在Java 8中,你可以写
Collection<Entity> entities = Arrays.asList(new Entity(1, "one"),
new Entity(11, "eleven"), new Entity(100, "one hundred"));
// get a collection of all the ids.
List<Long> ids = entities.stream()
.map(Entity::getId).collect(Collectors.toList());
System.out.println(ids);
指纹
[1, 10, 100]
可以想象,这在Java 7或更低版本中是相当丑陋的。请注意,当应用于 map() means 时,在每个元素上调用此方法。Entity.getId
现在,真正有趣的部分是你可以做到这一点。
List<Long> ids = entities.parallelStream()
.map(Entity::getId).collect(Collectors.toList());
在大多数情况下,使用并行流会损害性能,但它使尝试和查看变得非常容易(可能太容易;)
最有效的方法是拥有或构建地图。
Map<Long, Entity> entitiesMap = ...
// get all ids
Collection<Long> addIds = entitiesMap.keySet();
// look up entities by id.
List<Long> ids = ...
List<Entity> matching = new ArrayList<>();
for(Long id: ids)
matching.add(entitiesMap.get(id));