我认为是
因为每次系统调用都需要耗费大量资源
bufferedreader我想起的是一个缓冲的作用
比如说我要读1M的东西
一次读1k,读1024次,缓冲读取
要比一次读1个字节,读1024*1024次要快
因为减少了大量的系统的调用开销我也是菜鸟,不一定对,但我想应该是这个意思
:)
因为每次系统调用都需要耗费大量资源
bufferedreader我想起的是一个缓冲的作用
比如说我要读1M的东西
一次读1k,读1024次,缓冲读取
要比一次读1个字节,读1024*1024次要快
因为减少了大量的系统的调用开销我也是菜鸟,不一定对,但我想应该是这个意思
:)
如果外界有请求,就会到这里存取,如果内存里没有才到物理流里再去读。即使读,也是再8k。
而直接读物理流,是按字节来读。
对物理流的每次读取,都有IO操作。IO操作是最耗费时间的。BufferedReader就是减少了大量IO操作,而为你节省了时间。
而一次IO的来回操作却要耗费大量时间。
好比是一辆大型汽车(设装100人),要去车站接人到公司,接一个人也是接,接100个人也是接,而时间一样。显然,接100个人最划算。物理流就是一次一个字节(一个人)
Buffered就是一次8k个字节(100个人)
对于读取定长字节文件,当然BufferedReader更快了!