统计文本中‘b’出现的次数,直接读取和缓冲流读取都太慢了 ,自定义缓冲块大小读取,不知道具体要多少可以实现最大优化,就写了个循环实现
long mint=40;
int len;
int x=0,count=0;
for(int i=1;i<50;i++)//循环几次,倍数自行调节,试过之后50差不多
{
count=0;
long t=System.currentTimeMillis();
FileInputStream fis =new FileInputStream("D:\\blabla.txt");
byte buf[]=new byte[i*4096];
while((len=fis.read(buf)!=-1)
{
for(int j=0;j<len;j++)
{
if(buf[j]=='b')
count++;
}
}
fis.close();
t=System.currentTimeMillis()-t;
if(t<mint)
{
mint=t;
x=i*4096;
}
}
System.out.println("出现b的次数"+count);
System.out.println("最快运行时间"+mint);
System.out.println("缓冲块大小"+x);