Java StreamAPI简析及示例

Java StreamAPI

Stream 作为 Java 8 的一大亮点,它与 java.io 包里的 InputStream 和 OutputStream 是完全不同的概念。它也不同于 StAX 对 XML 解析的 Stream,也不是 Amazon Kinesis 对大数据实时处理的 Stream。Java 8 中的 Stream 是对集合(Collection)对象功能的增强,它专注于对集合对象进行各种非常便利、高效的聚合操作(aggregate operation),或者大批量数据操作 (bulk data operation)。Stream API 借助于同样新出现的 Lambda 表达式,极大的提高编程效率和程序可读性。同时它提供串行和并行两种模式进行汇聚操作,并发模式能够充分利用多核处理器的优势,使用 fork/join 并行方式来拆分任务和加速处理过程。通常编写并行代码很难而且容易出错, 但使用 Stream API 无需编写一行多线程的代码,就可以很方便地写出高性能的并发程序。所以说,Java 8 中首次出现的 java.util.stream 是一个函数式语言+多核时代综合影响的产物。

参考:https://www.ibm.com/developerworks/cn/java/j-lo-java8streamapi/

使用JavaParallelStreamAPI计算素数效率对比

package paralellStreamAPI;
import java.util.ArrayList;
import java.util.List;
import java.util.Random;

/**
 * 
 * java并行计算
 * 
 * @author x1c
 *
 */
public class ParalellStreamAPI {
	static List<Integer> nums = new ArrayList<>();
	//初始化10万个1000000-2000000的数
	static {
		for (int i = 0; i < 10000; i++) {
			Random random = new Random();
			nums.add(1000000 + random.nextInt(1000000));
		}
	}
	
	public static void main(String[] args) {
		System.out.println(nums);
		
		long start = System.currentTimeMillis();
		nums.forEach(v->isPrime(v));
		long end = System.currentTimeMillis();
		System.out.println("普通方法计算时间:"+(end - start));
		
		//使用Java parallel stream API  Since: 1.8
		start =System.currentTimeMillis();
//		nums.parallelStream().forEach(t->isPrime(t));
		nums.parallelStream().forEach(ParalellStreamAPI::isPrime);
		end = System.currentTimeMillis();
		
		System.out.println("JavaParallelStreamAPI计算素数时间:"+ (end - start));
	}
	
	static boolean isPrime(int num) {
		for (int i = 2; i < num/2; i++) {
			if (num%2 == 0) {
				return false;
			}
		}
		return true;
	}
}

普通方法计算时间:92
JavaParallelStreamAPI计算素数时间:12
普通方法计算时间:90
JavaParallelStreamAPI计算素数时间:11

可看出效率相差近10倍!所以用JavaStreamAPI高效率的要解决的问题。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值