这篇文章主要讲解了“JDK8 Stream性能介绍”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JDK8 Stream性能介绍”吧!
创新互联建站是一家专业提供孙吴企业网站建设,专注与成都做网站、网站建设、外贸营销网站建设、成都h5网站建设、小程序制作等业务。10年已为孙吴众多企业、政府机构等服务。创新互联专业的建站公司优惠进行中。
在编写代码时,想用jdk8的stream替换以前的for循环,代码如下:
//for方法 Setkeys = Sets.newHashSetWithExpectedSize(list.size()); for (T data : list) { keys.add(getWrapredisKey(data)); } //stream方法 Set keys = list.stream().map(this::getWrapRedisKey).collect(Collectors.toSet());
stream
可以非常优雅的一行代码就解决,而for
则需要三行代码,生产力大大提高。
但是for
循环可以实现初始化容量,这在频繁add
触发rehash
、链表转红黑树
时,能大大提高性能,那么stream
的api
的Collectors.toSet
方法有没有设置初始化容量。
查看源码:
Talking is cheap,show me the code
简单写了一个测试代码
public static void main(String[] args) { int expectSize = 100000; Listsource = generateData(expectSize); long start = System.currentTimeMillis(); testFor(source); //testStream(source); System.out.println(System.currentTimeMillis() - start); } private static void testFor(List source) { Set sets = Sets.newHashSetWithExpectedSize(source.size()); for (String s : source) { sets.add(s); } } private static void testStream(List source) { source.stream().collect(Collectors.toSet()); } private static List generateData(int size) { List list = Lists.newArrayListWithCapacity(size); for(int i = 1; i <= size; i++) { list.add(UUIDUtils.generateId()); } return list; }
结果是10w数据是,for比stream快2-3倍...
在数据量比较大,同时要求相应时间场景下,应该还是使用for或者在使用stream前预设集合容量。
感谢各位的阅读,以上就是“JDK8 Stream性能介绍”的内容了,经过本文的学习后,相信大家对JDK8 Stream性能介绍这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是创新互联,小编将为大家推送更多相关知识点的文章,欢迎关注!