免费注册 查看新帖 |

Chinaunix

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

bash和perl在处理for循环时的效率对比 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-11-21 16:55 |只看该作者 |倒序浏览
walkerxk@www:~$ cat a.sh
#!/bin/bash
N=1000
for ((I=1;I<$N;I++))
do
J=$(echo $N/10|bc)
if [ $(expr $I % $J) -eq 0 ]
then
echo $I >sh.log
fi
done
walkerxk@www:~$ cat a.pl
#!/usr/bin/perl
$n=1000;
open($f,">pl.log");
for ($i=1;$i<$n;$i++)
{
$j=$n/10;
if (0==$i%$j)
{
print $f $i."\n";
}
}
walkerxk@www:~$ time ./a.pl

real    0m0.008s
user    0m0.004s
sys     0m0.004s
walkerxk@www:~$ time ./a.sh

real    0m11.770s
user    0m3.304s
sys     0m5.664s
walkerxk@www:~$
两千多倍,谁能告诉我为什么?
如果我把if条件注释掉:
walkerxk@www:~$ time ./a.pl

real    0m0.069s
user    0m0.004s
sys     0m0.004s
walkerxk@www:~$ time ./a.sh

real    0m23.459s
user    0m1.684s
sys     0m3.808s
perl增加的时间应该是用在写文件上了,如过我重新执行a.pl,时间会变成:
walkerxk@www:~$ time ./a.pl

real    0m0.009s
user    0m0.000s
sys     0m0.008s
walkerxk@www:~$ time ./a.pl

real    0m0.009s
user    0m0.000s
sys     0m0.004s
walkerxk@www:~$

论坛徽章:
1
荣誉会员
日期:2011-11-23 16:44:17
2 [报告]
发表于 2007-11-21 17:02 |只看该作者
shell脚本每次循环都调用了bc 慢就正常啦

论坛徽章:
8
摩羯座
日期:2014-11-26 18:59:452015亚冠之浦和红钻
日期:2015-06-23 19:10:532015亚冠之西悉尼流浪者
日期:2015-08-21 08:40:5815-16赛季CBA联赛之山东
日期:2016-01-31 18:25:0515-16赛季CBA联赛之四川
日期:2016-02-16 16:08:30程序设计版块每日发帖之星
日期:2016-06-29 06:20:002017金鸡报晓
日期:2017-01-10 15:19:5615-16赛季CBA联赛之佛山
日期:2017-02-27 20:41:19
3 [报告]
发表于 2007-11-21 17:06 |只看该作者
N=1000
for ((I=1;I<$N;I++))
do
J=$(echo $N/10|bc)
if [ $(expr $I % $J) -eq 0 ]
then
echo $I >sh.log
fi
至少发起、终结了3000个进程

论坛徽章:
0
4 [报告]
发表于 2007-11-21 17:18 |只看该作者
我把bc去掉,还是很慢
real    0m0.176s
user    0m0.084s
sys     0m0.060s

论坛徽章:
0
5 [报告]
发表于 2007-11-21 17:20 |只看该作者
walkerxk@www:~$ time ./a.pl
real    0m0.007s
walkerxk@www:~$ time ./a.pl
real    0m0.008s
walkerxk@www:~$ time ./a.sh
real    0m0.252s
walkerxk@www:~$ time ./a.sh
real    0m0.236s
walkerxk@www:~$ time ./a.sh
real    0m0.286s
walkerxk@www:~$ time ./a.sh
real    0m0.234s

论坛徽章:
0
6 [报告]
发表于 2007-11-21 17:21 |只看该作者
原帖由 waker 于 2007-11-21 17:06 发表
N=1000
for ((I=1;Ish.log
fi
至少发起、终结了3000个进程

有什么办法可以优化么?bc已经去掉了,bc是因为一开始的测试才加进去的。

论坛徽章:
1
荣誉会员
日期:2011-11-23 16:44:17
7 [报告]
发表于 2007-11-21 17:22 |只看该作者
原帖由 walkerxk 于 2007-11-21 17:18 发表
我把bc去掉,还是很慢
real    0m0.176s
user    0m0.084s
sys     0m0.060s

perl不是bash

论坛徽章:
0
8 [报告]
发表于 2007-11-21 17:36 |只看该作者
还好一般服务器管理不用用到这么多的for循环,不知道运行时CPU负载怎么样。我看一下。
CPU占用差不多。

[ 本帖最后由 walkerxk 于 2007-11-21 17:41 编辑 ]

论坛徽章:
0
9 [报告]
发表于 2007-11-21 17:52 |只看该作者
没办法,就是把bash循环体中的语句全拿掉,在那空转,还是比perl慢许多,bash的长处不在于速度

论坛徽章:
0
10 [报告]
发表于 2007-11-23 18:04 |只看该作者
原帖由 seeLnd 于 2007-11-21 17:52 发表
没办法,就是把bash循环体中的语句全拿掉,在那空转,还是比perl慢许多,bash的长处不在于速度

问题是bash不能空转,空转就报错:
./a.sh: line 10: 在未预料的“done”附近出现语法错误
./a.sh: line 10: `done'
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP