負荷を小さくするには?
匿名
1999/06/28(月) 02:41:50
#!/usr/bin/perl
$datafile = "./log.txt";
open(IN,$datafile);
@IN=<IN>;
for ($i=0; $i<20; $i++) {
print $IN[$i];
}
close(IN);
といううふうに、先頭の20行を表示するものを
作ったのですが、他に負荷を小さく同じような処理をする方法ありますか?
何度も利用するのでなるべく負荷をかけたくないです。
お願いします。
Aurai
[E-Mail]
1999/06/28(月) 05:44:20
open(IN,$datafile);
for(0..19){$_=<IN>;print;}
close(IN);
はどうでしょう
細かいパフォーマンスは測ったことがありませんが
データファイルが小さいなら一気に読み込んだ方が早いんでしょうか?
ふじ
1999/06/28(月) 15:21:03
以下のようなコードで測定してみました。
(環境:Celeron 333, 128MB, Windows NT4.0, Perl 5.005_03)
#!/usr/local/bin/perl
use Benchmark;
open (OUT , "> result.txt");
$count = 1000;
$datafile = "data.txt";
@t = timethese($count , {
'ALL ' => '&all;',
'STEP' => '&step;'
});
exit;
sub all{
open (DATA, "< ./$datafile");
@data = <DATA>;
for ($i=0; $i<20; $i++) {
print OUT $data[$i];
}
close DATA;
}
sub step{
open (DATA, "< ./$datafile");
for ($i=0; $i<20; $i++) {
$_ = <DATA>;
print OUT $_;
}
close DATA;
}
結果、
data.txt : 100 lines , 6.4KB
ALL : 3 wallclock secs ( 1.71 usr + 0.54 sys = 2.25 CPU)
STEP: 1 wallclock secs ( 0.60 usr + 0.44 sys = 1.04 CPU)
data.txt : 1000 lines , 65KB
ALL: 14 wallclock secs (11.28 usr + 1.69 sys = 12.97 CPU)
STEP: 1 wallclock secs ( 0.65 usr + 0.40 sys = 1.05 CPU)
data 10000 lines , 660KB
ALL : 123 wallclock secs (112.23 usr + 9.75 sys = 121.99 CPU)
STEP: 2 wallclock secs ( 0.59 usr + 0.44 sys = 1.03 CPU)
ということで。一行ずつ読む方が速いです。メモリも喰わないし。
>データファイルが小さいなら一気に読み込んだ方が早いんでしょうか?
data.txt : 20lines , 1.26KB
ALL : 15 wallclock secs ( 7.41 usr + 4.56 sys = 11.97 CPU)
STEP: 13 wallclock secs ( 5.36 usr + 4.36 sys = 9.71 CPU)
(註:これだけ $count = 10000 としてます)
データファイルが小さくても、1行ずつ読んだ方が速いみたいです。
配列の処理に時間を喰われるんでしょうか。
長文失礼。
匿名
1999/06/30(水) 07:23:55
お返事ありがとうございます。
負荷を計るようなソフトがあるんでしょうか?
ふじ
1999/06/30(水) 13:37:34
Perlの標準ライブラリに Benchmark.pm ってのがありまして、
それを使ってみました。
perl/lib/ に入っているので、使い方はそれを見て下さい。