关于多线程运行效率的在线讨论
我自己编写的一个程序。
大概如下模式:
1,有两个大小各位100mb的文件。
2,用两个线程各自同时处理他们
3,这两个线程的运行函数都是一样的
程序处理完毕,费时40秒。
然而,当我用单线程去处理一个200mb的文件却只需要30秒。处理函数同上面的一样。
多线程的效率为什么发挥不出来呢?
我想出现这种问题的原因,可能是下面的情况,但不知道对否?求讨论,求指正。
由于两个函数共享一个函数,也就共享一个代码段,在同一时间上,一个代码段只允许一个线程读取,所以双线程
实质上并没有起到并行运行的作用,反而增加了线程切换的开销。
大概如下模式:
1,有两个大小各位100mb的文件。
2,用两个线程各自同时处理他们
3,这两个线程的运行函数都是一样的
程序处理完毕,费时40秒。
然而,当我用单线程去处理一个200mb的文件却只需要30秒。处理函数同上面的一样。
多线程的效率为什么发挥不出来呢?
我想出现这种问题的原因,可能是下面的情况,但不知道对否?求讨论,求指正。
由于两个函数共享一个函数,也就共享一个代码段,在同一时间上,一个代码段只允许一个线程读取,所以双线程
实质上并没有起到并行运行的作用,反而增加了线程切换的开销。
作者: lc1987813 发布时间: 2011-05-24
如果机器配置了多个处理器(核心),多线程就能充分利用CPU
作者: mymtom 发布时间: 2011-05-24
老兄你没有回答我的问题啊,我的解释是对还是错的呢?
引用楼主 lc1987813 的回复:
我自己编写的一个程序。
大概如下模式:
1,有两个大小各位100mb的文件。
2,用两个线程各自同时处理他们
3,这两个线程的运行函数都是一样的
程序处理完毕,费时40秒。
然而,当我用单线程去处理一个200mb的文件却只需要30秒。处理函数同上面的一样。
多线程的效率为什么发挥不出来呢?
我想出现这种问题的原因,可能是下面的情况,但不知道对否?求讨论,求指正。
……
我自己编写的一个程序。
大概如下模式:
1,有两个大小各位100mb的文件。
2,用两个线程各自同时处理他们
3,这两个线程的运行函数都是一样的
程序处理完毕,费时40秒。
然而,当我用单线程去处理一个200mb的文件却只需要30秒。处理函数同上面的一样。
多线程的效率为什么发挥不出来呢?
我想出现这种问题的原因,可能是下面的情况,但不知道对否?求讨论,求指正。
……
作者: lc1987813 发布时间: 2011-05-24