免费注册 查看新帖 |

Chinaunix

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

perl 1000次连接字符串的循环花了4分钟 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-02-12 11:56 |只看该作者 |倒序浏览
用perl 1000次连接字符串的循环花了4分钟

就是下面的几行代码

for ($i=1;$i<=1000;$i++)
{

        $threads = $threads." ('$i', '2', '0', '0', '0', '0', 'admin', '1', 'testestestes', '1234342389', '1234342389', 'admin', '2', '0', '0', '0', '0', '0', '0', '0', '0', '0', '0', '0', '0', '0');";
}

print "INSERT INTO `threads` VALUES".threads;
exit();



竟然执行了 4分35秒。
请教达人,为什么会这么慢? 使用的是 activeperl 5.10 .

测试了一下用cgi 方式只要1秒左右,用 perl 直接解释运行却要4分钟。

论坛徽章:
3
戌狗
日期:2014-09-10 17:07:162015年辞旧岁徽章
日期:2015-03-03 16:54:15wusuopu
日期:2016-06-17 17:43:45
2 [报告]
发表于 2009-02-12 12:34 |只看该作者

回复 #1 想像的瞬间 的帖子

每次都是这么慢吗

论坛徽章:
0
3 [报告]
发表于 2009-02-12 12:43 |只看该作者

  1. use Benchmark;
  2. use Data::Dumper;
  3. my $t0 = new Benchmark;
  4. my $threads;
  5. for (my $i=1;$i<=1000;$i++)
  6. {

  7.         $threads = $threads." ('$i', '2', '0', '0', '0', '0', 'admin', '1', 'testestestes', '1234342389', '1234342389', 'admin', '2', '0', '0', '0', '0', '0', '0', '0', '0', '0', '0', '0', '0', '0');";
  8. }
  9. print $threads;

  10. my $t1 = new Benchmark;
  11. my $td = timediff($t1, $t0);
  12. print "the code took:",timestr($td),"\n";
复制代码


  1. the code took: 0 wallclock secs ( 0.00 usr +  0.00 sys =  0.00 CPU)
复制代码


不是这的问题吧
才1000次Benchmark都测不出来

论坛徽章:
0
4 [报告]
发表于 2009-02-12 13:08 |只看该作者
我用 editplus 运行了,运行完了它有一个输出完成时间的,上面提示是4分钟

论坛徽章:
0
5 [报告]
发表于 2009-02-12 13:10 |只看该作者
原帖由 ynchnluiti 于 2009-2-12 12:34 发表
每次都是这么慢吗


嗯,每次都要3到4分钟的样子

论坛徽章:
0
6 [报告]
发表于 2009-02-12 13:15 |只看该作者
我也用 editplus ,我怎么就不是 4 分钟呢

论坛徽章:
0
7 [报告]
发表于 2009-02-12 13:15 |只看该作者

回复 #4 想像的瞬间 的帖子

你把输出去掉
再试一下

论坛徽章:
0
8 [报告]
发表于 2009-02-12 13:26 |只看该作者

回复 #1 想像的瞬间 的帖子

改成数组的
push @threads

论坛徽章:
0
9 [报告]
发表于 2009-02-12 14:16 |只看该作者

用foreach

#!/usr/bin/perl



use strict;

my $threads;
my $s_time = time();

foreach (1..100000) {
&nbsp;&nbsp;
&nbsp;&nbsp;$threads = $threads." ('$_', '2', '0', '0', '0', '0', 'admin', '1', 'testestestes', '1234342389', '1234342389', 'admin', '2', '0', '0', '0', '0', '0', '0', '0', '0', '0', '0', '0', '0', '0')";

}

my $e_time = time() - $s_time;

print $e_time;



循环的是 100000次 比你的高100倍。时间是75s
perl 一般不使用for, 效率没有foreach效率高.

[ 本帖最后由 luckyelement 于 2009-2-12 14:18 编辑 ]

论坛徽章:
0
10 [报告]
发表于 2009-02-12 14:49 |只看该作者
谢谢楼上的大哥们,测试了一上,是
print 占用了很长时间,没用 print ,用 foreach (1..1000) 循环连接字符串不到1秒,加了print 输出就要3分钟以上。

print 占用了这么长时间?
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP