一条语句的效率问题
my @temp = ($temp_str =~ /.*vhosts\/(.*)\/htdocs.*/);
这个语句的效率很低,加上他和不加他执行速度差了好多倍,有没有什么优化的办法
这个语句的效率很低,加上他和不加他执行速度差了好多倍,有没有什么优化的办法
作者: cocowool 发布时间: 2011-05-26
本帖最后由 zhlong8 于 2011-05-26 10:45 编辑
第一个 .* 和最后一个 .* 去掉。不用 @tmp = 直接捕获你需要的那部分。后一条可以让程序快2倍,用Benchmark 多测试测试
第一个 .* 和最后一个 .* 去掉。不用 @tmp = 直接捕获你需要的那部分。后一条可以让程序快2倍,用Benchmark 多测试测试
作者: zhlong8 发布时间: 2011-05-26
回复 zhlong8
恩,去掉了*, 捕获是必要的,因为后需要用到中间的字符串
后来time测试发现
chomp(my $time = `date -d yesterday +%d-%b-%Y` );
这一条占用资源也比较多,写在循环里面了,白费了很多时间
恩,去掉了*, 捕获是必要的,因为后需要用到中间的字符串
后来time测试发现
chomp(my $time = `date -d yesterday +%d-%b-%Y` );
这一条占用资源也比较多,写在循环里面了,白费了很多时间
作者: cocowool 发布时间: 2011-05-26
QUOTE:
回复 zhlong8
恩,去掉了*, 捕获是必要的,因为后需要用到中间的字符串
后来time测试发现
chomp( ...
cocowool 发表于 2011-05-26 10:51
恩,去掉了*, 捕获是必要的,因为后需要用到中间的字符串
后来time测试发现
chomp( ...
cocowool 发表于 2011-05-26 10:51
/(vhosts\/(.*)\/htdocs)/ 可以用 $1 $2 捕获,两种方法速度是 5:1.8 用 $1 $2 快很多。循环中用到 `` 自然慢
作者: zhlong8 发布时间: 2011-05-26