两者之间的区别是什么(如果有的话):
sub foobar() { # doing some stuff }
和
sub foobar { # doing some stuff }
我看到了一些,第一种语法有时无法编译.
解决方法
通过将()放在子例程名称的末尾,您将为其提供原型.原型为Perl提供了有关您将传递给子例程的参数的数量和类型的提示.有关详情,请参见
this section in perlsub.
具体来说,()是空原型,告诉Perl这个子例程不带参数,如果你随后用参数调用这个子例程,Perl将抛出一个编译错误.这是一个例子:
#!/usr/bin/perl use strict; use warnings; use 5.010; sub foo { say 'In foo'; } sub bar() { say 'In bar'; } foo(); bar(); foo(1); bar(1);
这个输出是:
Too many arguments for main::bar at ./foobar line 18,near "1)" Execution of ./foobar aborted due to compilation errors.
值得注意的是,Perl的原型实现通常不如人们通常认为的那样有用,而且在一些特殊情况之外,大多数Perl专家都会避免使用它们.我建议你这样做.从Perl v5.22开始,实验性的“签名”功能正在进行测试,希望能够完成其他语言的程序员从原型中获得的许多目标.