带括号和没有括号的Perl子声明之间有什么区别?

前端之家收集整理的这篇文章主要介绍了带括号和没有括号的Perl子声明之间有什么区别?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
两者之间的区别是什么(如果有的话):
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.

这是最后一次调用bar()(参数为1的那个)导致此错误.

值得注意的是,Perl的原型实现通常不如人们通常认为的那样有用,而且在一些特殊情况之外,大多数Perl专家都会避免使用它们.我建议你这样做.从Perl v5.22开始,实验性的“签名”功能正在进行测试,希望能够完成其他语言的程序员从原型中获得的许多目标.

原文链接:https://www.f2er.com/Perl/241735.html

猜你在找的Perl相关文章