1.<STDIN>为行输入操作,但其实际上是对一个文件句柄(filehandle)的行输入操作(有<>表示)。本章后面将更多的介绍文
件句柄(filehandle)。
$line = <STDIN>; #读入下一行;
chomp($line); #去掉结尾的换行符
chomp($line=<STDIN>) #同上,更常用的方法
2.行输入操作在到达文件的结尾时将返回undef,这对于从循环退出时非常方便的:
while (defined($line = <STDIN>)) {
print “I saw $line”;
}
第一行代码值得仔细说明:我们将输入的字符串读入一个变量,检查其是否defined,如果是(意味着我们没有到达输入的
结尾),则执行while 的循环体。因此,在循环的内部,我们将看到每一行,一行接着一行。
3.在这种类型的循环中,你不能将chomp 操作插入条件表达式中,因此这通常是循环体的第一条语句。
4.
while (defined($_ = <STDIN>)){
print “I saw $_”;
}
这种简写只在特定的情况下有效,默认的情况下不会将一行读入变量$_。仅当while
循环的条件判断部分只包含行输入操作才有效。如果在条件判断部分还有别的内容,则上述简写无效。
5.在列表context 中使用行输入操作时,则会将所有的行(剩下的)当作一个列表,而每一行作为列表的一个元素:
foreach(<STDIN>){
print “I saw $_”;
}
同样,行输入操作和Perl 的默认变量$_没有必然的联系。在上例中,foreach 默认的控制变量为$_。因此,此循环将每一行
赋给$_。
6.在while 循环中,Perl 读入一行,将它赋给变量,然后进入循环。再回到开头,读入下一行。但
在foreach 循环中,由于行输入操作在列表的context 中使用,因为foreach 需要一个列表作为其参数。因此,它在循环执行
前会将所有的输入读入。这种区别在读入一个400MB 的web 服务器的log 文件时非常明显。通常使用while 循环是一种更
好的方法,因为它一次处理一行输入。
7.尖括号◆输入(diamond operator):<>。这种方法对于书写类似于标准Unix◆工具的程序非常有用。如果
想写一个Perl 程序,使它具有像cat, sed, awk, sort, grep, lpr, 以及许多别的应用程序类似的功能,则<>将帮上你的大忙。
8.当程序开始运行运行时,它有0 个或多个调用参数,这由此程序决定。这通常出现在shell 中,此列表由你命令行中输入的内容决定。在
后面将看到,调用程序可以使用许多字符串作为调用参数(invocation arguments)。由于它们经常出现在命令行中,因此有时亦被称作命
令行参数(command-line arguments)。
$ ./my_program fred barney betty