免费注册 查看新帖 |

Chinaunix

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

请教个grep cpu占用高的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-08-06 16:16 |只看该作者 |倒序浏览
写了段代码:
sub s_check_sz
#########################################################
#比较数组中差异的部分,并返回差异部分                   #
#调用方式:s_check_sz(\@数组1,\@数组2)                  #
#返回值:在数组1中存在,不在数组2中存在的数据           #
#已知BUG:无                                            #
#########################################################
{
        my ($tmp1,$tmp2)=@_;
        my (@retur_num);
        foreach my $tp1 (@$tmp1)
        {
                my ($sz_nu)=grep /$tp1/,@$tmp2;
                if (!$sz_nu )
                {
                        push (@retur_num,$tp1);
                }
        }
        return @retur_num;
}

运行的时候发现2个数组都在近2万个的时候,机器的cpu占用率基本在96%~99%之间浮动,请问怎么解决下这个问题?

论坛徽章:
0
2 [报告]
发表于 2009-08-06 16:51 |只看该作者

回复 #1 SAS 的帖子

楼主试试这种方法
  1. my ($tmp1,$tmp2)=@_;
  2. my %hash;
  3. my @return_num;
  4. for(@$tmp1) {
  5.     $hash{$_} = 1;
  6. }
  7. my $count = 0;
  8. for(@$tmp2) {
  9.     $return_num[$count++] = $_ if($hash{$_});
  10. }
  11. return @return_num;
复制代码


改了一下,这种速度更快

BTW,建议s_check_sz返回数组的引用,而不是数组,按照楼主描述的应用环境,数据量应该还是蛮大的,返回数组引用性能上会更好一些

[ 本帖最后由 yashiro_lj 于 2009-8-6 17:02 编辑 ]

论坛徽章:
0
3 [报告]
发表于 2009-08-06 17:53 |只看该作者
谢了

现在的占用率很低了。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP