免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2506 | 回复: 5
打印 上一主题 下一主题

perl里的多线程问题?? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-08-21 20:23 |只看该作者 |倒序浏览
部分代码如下:
use Thread;

foreach my $x (0..$#a) {
                my $a_1=$a[$x];
                my @array;
                foreach my $y (0..$#spots) {
                        my $a_2=$spots[$y];       
                                my $euc=Thread->new(\&Euc,$a,$samples,$a_1,$a_2);
                                push (@array,$euc);
                }
                for my $i(0..$#array) {
                        my $result=$array[$i]->join;
                        if($min > $result) {
                                        $min=$result;
                                        $b_pair[0]=$a[$x];
                                        $b_pair[1]=$spots[$i];
                                }
                        }
                }


print $min."\t".$b_pair[0]."\t".$b_pair[1]."\n";


其中Euc是一个函数,想通过循环来得到最小值,及其对应在数组@a,@spots里的值,由于数据量比较大,运行起来比较慢,已经运行了5个小时都没有结果,所以想改用多线程,但是我发现用多线程,速度还是很慢,到现在还是没出结果。所以想请教各位大虾,是不是我写的代码有问题,还是说不应该用多线程,而要用到进程。如果是用多进程,又该怎么写呢?

论坛徽章:
0
2 [报告]
发表于 2010-08-21 20:49 |只看该作者
有多少个核或者CPU?

论坛徽章:
0
3 [报告]
发表于 2010-08-22 13:35 |只看该作者
回复 2# 黑色阳光_cu


    大概有50个cpu吧。

论坛徽章:
0
4 [报告]
发表于 2010-08-22 15:21 |只看该作者
好多循环嵌套呀,数据量大的话,内存占用不是一般的多吧

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
5 [报告]
发表于 2010-08-23 10:13 |只看该作者
用多进程吧,就是传统的fork,然后一个个的wait pid就好了。具体可以搜搜论坛或是网上的例子,很多的。
我这里双CPU,16核。算起东西来很快的。以前大概1周算完的数据现在也就几个小时。

论坛徽章:
0
6 [报告]
发表于 2010-08-26 19:18 |只看该作者
回复 5# py


    谢谢版主,谢谢。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP