Reading a single file with Multiple Thread: should speed up?

后端 未结 3 422
孤独总比滥情好
孤独总比滥情好 2020-12-06 18:57

I\'m reading a file which conatins 500000 rows. I\'m testing to see how multiple thread speed up the process....

private void multiThreadRead(int num){

             


        
相关标签:
3条回答
  • 2020-12-06 19:22

    Since file reading is mainly waiting for disk I/O, you have the problem that the disk won't spin faster just because it's used by many threads :)

    0 讨论(0)
  • 2020-12-06 19:29

    Reading from a file is an inherently serial process, assuming no caching, meaning there is a limit to how fast you can retrieve data from a file. Even without file locks (i.e. opening the file read-only) all the threads after the 1st will just block on the disk read so you make all the other threads wait and whichever one is active when the data becomes available is the one that processes the next block.

    0 讨论(0)
  • 2020-12-06 19:44

    The reason you are seeing a slow down when reading in parallel is because the magnetic hard disk head needs to seek the next read position (taking about 5ms) for each thread. Thus, reading with multiple threads effectively bounces the disk between seeks, slowing it down. The only recommended way to read a file from a single disk is to read sequentially with one thread.

    0 讨论(0)
提交回复
热议问题