java读取大txt文件_Java读取具有7000万行文本的大文本文件
小編典典
1)我確定速度沒有差異,兩者都在內部使用FileInputStream和緩沖
2)您可以進行測量并親自查看
3)雖然沒有性能優勢,但我喜歡1.7方法
try (BufferedReader br = Files.newBufferedReader(Paths.get("test.txt"), StandardCharsets.UTF_8)) {
for (String line = null; (line = br.readLine()) != null;) {
//
}
}
4)基于掃描儀的版本
try (Scanner sc = new Scanner(new File("test.txt"), "UTF-8")) {
while (sc.hasNextLine()) {
String line = sc.nextLine();
}
// note that Scanner suppresses exceptions
if (sc.ioException() != null) {
throw sc.ioException();
}
}
5)這可能比其余的更快
try (SeekableByteChannel ch = Files.newByteChannel(Paths.get("test.txt"))) {
ByteBuffer bb = ByteBuffer.allocateDirect(1000);
for(;;) {
StringBuilder line = new StringBuilder();
int n = ch.read(bb);
// add chars to line
// ...
}
}
它需要一些編碼,但是由于,它確實可以更快ByteBuffer.allocateDirect。它允許操作系統從文件ByteBuffer直接讀取字節,而無需復制
6)并行處理肯定會提高速度。創建一個大字節緩沖區,運行多個任務,將文件中的字節并行讀取到該緩沖區中,當準備好找到行的第一行時,創建一個String,然后查找下一個…
2020-09-08
總結
以上是生活随笔為你收集整理的java读取大txt文件_Java读取具有7000万行文本的大文本文件的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: JavaScript变量声明+数据类型+
- 下一篇: (BFS)Dungeon Master(