我在 Komodo IDE 和命令行中尝试了这个并得到了相同的结果。
如果你use
或require
一个文件,Perl 将文件名保存在%INC
. 这样可以确保文件只加载一次。您可以require
在许多不同的其他模块中使用相同的模块并使用sample::printMessage()
. 第一个require
将完成,其他所有将被忽略,因为$INC{'sample'} = './sample.pm'
.%INC
require sample;
require sample;
require sample;
sample::printMessage();
__END__
new message!
如果您use
使用模块而不是require
ing 它,这同样适用,因为use
只有 arequire
和 animport
在一个BEGIN
块中。在这两种情况下,Perl 都记住了这一点。我的假设(没有找到证明这一点的文档)是,调试器能够做同样的事情,甚至可以读取内部的%INC
.
现在,如果您do
是文件,则不会触发该%INC
机制,这意味着您可以一遍又一遍地文件。它不关心文件的名称。其后果是,如果您多次提交文件,即使没有.do
do
use warnings
do 'sample.pm';
do 'sample.pm';
do 'sample.pm';
__END__
Subroutine printMessage redefined at sample.pm line 4.
Subroutine printMessage redefined at sample.pm line 4.
new message!
我的猜测是调试器也不记得了,因此它不知道它已经加载了sample.pm
. 医生说:
使用 EXPR 的值作为文件名并将文件的内容作为 Perl 脚本执行。
do 'stat.pl';
很大程度上就像
eval `cat stat.pl`;
所以它只在文件中啜饮并执行内容。没有%INC
。调试器没有文件名(顺便说一下,EPIC 中的调试器与 Komodo IDE 中的调试器和命令行上的调试器相同,图形化的只是连接到 Perl 调试器)。因此,当代码显示时,您的断点将被忽略do
。
如果您希望调试器sample.pm
即使在第 5 行停止,也可以通过添加到上面的行do
来告诉调试器这样做。$DB::single = 1;
package sample;
sub printMessage
{
$DB::single = 1;
print 'new message!';
}
这记录在perldebug中。它将使调试器在下一行停止,相当于s在调试器中键入,或单击 EPIC 调试器中的单步按钮。
也可以看看: