java8
java8 stream和foreach哪个效率高?
stream和foreach哪个效率高?
使用for循环,串行Stream流,并行Stream流来对5亿个数字求和。看消耗的时间。
public class Demo06 {
private static long times 50000000000L
private long start
@Before
public void init() {
start ()
}
@After
public void destory() {
long end ()
(消耗时间: (end - start))
}
// 测试效率,parallelStream 120
@Test
public void parallelStream() {
(serialStream)
LongStream.rangeClosed(0, times)
.parallel()
.reduce(0, Long::sum)
}
// 测试效率,普通Stream 342
@Test
public void serialStream() {
(serialStream)
LongStream.rangeClosed(0, times)
.reduce(0, Long::sum)
}
// 测试效率,正常for循环 421
@Test
public void forAdd() {
(forAdd)
long result 0L
for (long i 1L i lt times i ) {
result i
}
}
}
我们可以看到parallelStream的效率是最高的。
Stream并行处理的过程会分而治之,也就是将一个大任务切分成多个小任务,这表示每个任务都是一个操作。
java里面的节点流和处理流是什么意思a?
按照流是否直接与特定的地方(如磁盘、内存、设备等)相连,分为节点流和处理流两类。
节点流:可以从或向一个特定的地方(节点)读写数据。如FileReader.
处理流:是对一个已存在的流的连接和封装,通过所封装的流的功能调用实现数据读写。如BufferedReader.处理流的构造方法总是要带一个其他的流对象做参数。一个流对象经过其他流的多次包装,称为流的链接。
JAVA常用的节点流有以下几个:
文 件 FileInputStream FileOutputStrean FileReader FileWriter 文件进行处理的节点流。
字符串 StringReader StringWriter 对字符串进行处理的节点流。
数 组 ByteArrayInputStream ByteArrayOutputStreamCharArrayReader CharArrayWriter 对数组进行处理的节点流(对应的不再是文件,而是内存中的一个数组)。
管 道 PipedInputStream PipedOutputStream PipedReaderPipedWriter对管道进行处理的节点流。
父 类 InputStream OutputStream Reader Writer
常用处理流(关闭处理流使用关闭里面的节点流)
缓冲流:BufferedInputStrean BufferedOutputStream BufferedReader BufferedWriter
增加缓冲功能,避免频繁读写硬盘。
转换流:InputStreamReader OutputStreamReader实现字节流和字符流之间的转换。
数据流 DataInputStream DataOutputStream 等-提供将基础数据类型写入到文件中,或者读取出来。