java序列化读取与文本文件读取数据效率对比
2008-08-08 16:36
483 查看
分别写入数据到序列化文件和文本文件中:
public static void main(String[] args) {
ArrayList al = new ArrayList();
try {
FileWriter fw = new FileWriter(new File("e://s.txt"));
for(int i=0;i<1000;i++){
String str = "000/t111/t222/t222/t222/t222/t222/t222/t222/t222/n";
al.add(str);
fw.write(str);
}
fw.close();
FileOutputStream fileStream = new FileOutputStream("e://s.obj");
ObjectOutputStream out = new ObjectOutputStream(fileStream);
out.writeObject(al);
out.close();
} catch (Exception e) {
e.printStackTrace();
}
}
然后写程序读取序列化文件和文本文件,并将数据赋值到ArrayList中。
序列化读取:
public static void main(String[] args) {
ArrayList al = new ArrayList();
try {
long t = System.currentTimeMillis();
FileInputStream fileStream = new FileInputStream("e://s.obj");
BufferedInputStream br = new BufferedInputStream(fileStream);
ObjectInputStream in = new ObjectInputStream(br);
al = (ArrayList)in.readObject();
in.close();
System.out.println(System.currentTimeMillis()-t);
} catch (Exception e) {
e.printStackTrace();
}
}
//文本文件读取:
public static void main(String[] args) {
ArrayList al = new ArrayList();
try {
long t = System.currentTimeMillis();
FileReader fw = new FileReader(new File("e://s.txt"));
BufferedReader br = new BufferedReader(fw);
String s = br.readLine();
while (s != null) {
al.add(s);
s = br.readLine();
}
br.close();
fw.close();
System.out.println(System.currentTimeMillis()-t);
} catch (Exception e) {
e.printStackTrace();
}
}
结论:
在行数i=1000时,序列化读取平均32,文本文件读取平均16。
在行数i=10000时,序列化读取平均46,文本文件读取平均46。
在行数i=100000时,序列化读取平均96,文本文件读取平均316。
故在大数据量读取时,使用序列化方式存取数据,效率较高;而在小数据量(小于10000行)时,使用文本文件存取数据效率较高。
public static void main(String[] args) {
ArrayList al = new ArrayList();
try {
FileWriter fw = new FileWriter(new File("e://s.txt"));
for(int i=0;i<1000;i++){
String str = "000/t111/t222/t222/t222/t222/t222/t222/t222/t222/n";
al.add(str);
fw.write(str);
}
fw.close();
FileOutputStream fileStream = new FileOutputStream("e://s.obj");
ObjectOutputStream out = new ObjectOutputStream(fileStream);
out.writeObject(al);
out.close();
} catch (Exception e) {
e.printStackTrace();
}
}
然后写程序读取序列化文件和文本文件,并将数据赋值到ArrayList中。
序列化读取:
public static void main(String[] args) {
ArrayList al = new ArrayList();
try {
long t = System.currentTimeMillis();
FileInputStream fileStream = new FileInputStream("e://s.obj");
BufferedInputStream br = new BufferedInputStream(fileStream);
ObjectInputStream in = new ObjectInputStream(br);
al = (ArrayList)in.readObject();
in.close();
System.out.println(System.currentTimeMillis()-t);
} catch (Exception e) {
e.printStackTrace();
}
}
//文本文件读取:
public static void main(String[] args) {
ArrayList al = new ArrayList();
try {
long t = System.currentTimeMillis();
FileReader fw = new FileReader(new File("e://s.txt"));
BufferedReader br = new BufferedReader(fw);
String s = br.readLine();
while (s != null) {
al.add(s);
s = br.readLine();
}
br.close();
fw.close();
System.out.println(System.currentTimeMillis()-t);
} catch (Exception e) {
e.printStackTrace();
}
}
结论:
在行数i=1000时,序列化读取平均32,文本文件读取平均16。
在行数i=10000时,序列化读取平均46,文本文件读取平均46。
在行数i=100000时,序列化读取平均96,文本文件读取平均316。
故在大数据量读取时,使用序列化方式存取数据,效率较高;而在小数据量(小于10000行)时,使用文本文件存取数据效率较高。
相关文章推荐
- java序列化读取与文本文件读取数据效率对比
- java序列化读取与文本文件读取数据效率对比
- java序列化读取与文本文件读取数据效率对比
- java序列化读取与文本文件读取数据效率对比
- java序列化读取与文本文件读取数据效率对比
- java序列化读取与文本文件读取数据效率对比
- java中向文本文件中读取数据之使用BufferedReader类
- JAVA基础 day23 IO流的其他类 (对象的序列化 管道流 RandomAccessFile类(随机读取文件) DateStream(操作基本数据类型的流) 操作数组的流 )字符编码问题
- java基础-输入流-读取文本文件中数据至字符串数组
- FIFO和Binder读取数据效率测试对比结果
- Java学习-013-文本文件读取实例源代码(两种数据返回格式)
- java缓冲字节流的复制数据,数据以数组读取、写入,效率更高
- java快速读取文本文件最后一行数据内容,文本文件非常大
- JAVA数据集合:Set与Get效率对比
- 关于vector push_back()与其他方式读取数据的效率对比
- java 数据与文本文件存储读取,文件大小计算。
- 关于vector push_back()与其他方式读取数据的效率对比(转)
- Java 快速读取文本文件最后一行数据
- Android中(java)读取以key=value形式保存在txt等文本文件的数据
- java读取文本文件数据