<>;
print $_
しかし、これは動作します:
while(<>){
print $_;
}
最初のバージョンは動作しないのはなぜ?
<>;
print $_
しかし、これは動作します:
while(<>){
print $_;
}
最初のバージョンは動作しないのはなぜ?
while (<>)
はwhile(defined($_ = <ARGV>))
の省略形ですが、<>;
はちょうど<ARGV>;
ですので。これはB::Deparse
モジュールで確認できます。ファイルexample.pl
#!/usr/bin/perl
use strict;
use warnings;
<>;
while (<>) {
}
コマンド
perl -MO=Deparse example.pl
を考えると
これはPerlの有名なDWIM ERYの一例である
use warnings;
use strict 'refs';
<ARGV>;
while (defined($_ = <ARGV>)) {
();
}
example.pl syntax OK
を印刷します。私はそれをやってから人々を停止するために行われていたと信じて無駄な
あなたが<>;
を言うとき、あなたが最も頻繁にあるので、実際には、それはおそらく有害になり、そこ無効コンテキストでの特殊なケース
<>
に何も値がされていない、と
for (<>) {
}
あなたがファイルハンドルから望まない行を捨てようとしています。 $_
を捕まえることは効率的ではなく、望ましいことでもありません。
Perl while (<>)
ステートメントの暗黙的な割り当ては$_
です。これは最初のスニペットにはありません。
これはman perlopに記載されている:
入力シンボル(
for(;;)
ループを装っても)while
文の条件内部唯一のものである場合のみと、値が自動的に割り当てられている場合グローバル変数$ _は以前にあったものを破壊します。
あなたが書かれたかのように第二1は、特殊なケースですので:
while (defined($_ = <>)) {
第一1は特殊なケースではありません。入力欄にはどこにでも を保存していないので、保存されませんでした。
「-MO」は何を意味していますか? –
'-Mmodule = arg1、arg2'は' use module qw/arg1 arg2 /; 'と同じですので、' -MO = Deparse'は次のようになります。 'use qw/deparse /;と等価です。 ['O'](http://perldoc.perl.org/O.html)モジュールは、複数のバックエンドモジュール(すなわち' B :: '名前空間にあるモジュール)を簡単に読み込むことを可能にします。 –