1.师兄之前常说为了提高系统效率要讲频繁读取的东西放在内存中,但是一直不明白这是什么意思,今天自己动手实现了将文件内容放在内存中,我这个文件为680M,一次性读取文件的话我的jvm内存太小,这个时候就要去修改JVM内存大小,可以直接在Eclipse里面进行修改,我修改为1G(嘿嘿当然这个时候电脑有点卡),其实读在内存中就是将内容放在静态变量中。在Eclipse里修改JVM的步骤如下:
package com.huawei;
import java.io.BufferedReader;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
public class ReadUtil {
private static ReadUtil readUtil = new ReadUtil();
public static List<String> pwTrail;
public static StringBuffer sb1 = new StringBuffer();
public static StringBuffer sb2 = new StringBuffer();
public static ReadUtil getInstance(){
return readUtil;
}
public StringBuffer readToMem(String fileName)
{
//pwTrail = new ArrayList<String>();
if(sb2.length()!=0){
return sb2;
}
try {
BufferedReader fileReader = new BufferedReader(new FileReader(new File(fileName)));
int len=0;
/*StringBuffer sb = new StringBuffer();*/
byte ch[] = new byte[1024];
while(fileReader.readLine()!= null)
{
// String str = String.valueOf(ch);
//System.out.println(fileReader.readLine());
String str = fileReader.readLine();
//StringBuffer SB=new StringBuffer();
sb1.append(str);
//pwTrail.add(str);
}
for(int i=0;i<10;i++)
sb2.append(sb1);
} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return sb2;
}
public static StringBuffer getSb2() {
return sb2;
}
public static void setSb2(StringBuffer sb2) {
ReadUtil.sb2 = sb2;
}
}
这个是主函数去调用读取的方法,代码如下:
package com.huawei;
import java.util.List;
public class ReadToMem {
/**
* @param args
*/
public static void main(String[] args) {
//ReadUtil readUtil =ReadUtil.getInstance();
//readUtil.readToMem("1.txt");
long start1 = System.currentTimeMillis();
ReadUtil readUtil2 =ReadUtil.getInstance();
//List<String> pwTrail2 = readUtil2.getPwTrail();
StringBuffer sb2 =readUtil2.readToMem("1.txt");
System.out.println("sb2的长度"+sb2.length());
long end1 = System.currentTimeMillis();
System.out.println(start1);
System.out.println(end1);
long time1=end1-start1;
System.out.println("读取第一个sb所需的时间:"+time1+" ms");
long start2 = System.currentTimeMillis();
ReadUtil readUtil3 =ReadUtil.getInstance();
StringBuffer sb3 =readUtil3.readToMem("1.txt");
System.out.println("sb3的长度"+sb3.length());
//List<String> pwTrail3 = readUtil2.getPwTrail();
long end2 = System.currentTimeMillis();
System.out.println(start2);
System.out.println(end2);
long time2=end2-start2;
System.out.println("读取第二个sb所需的时间:"+time2+" ms");
if(sb2.equals(sb3)){
System.out.println("sb2和sb3是相同的");
}
/*if(pwTrail2.size() == pwTrail3.size()){
System.out.println("一样");
}*/
}
}
对比两次结果就可见效率的提高不是一般的,O(∩_∩)O哈哈~。
截图: