perl encapsulate single variable in double quotes

后端 未结 5 1578
南方客
南方客 2021-01-12 11:06

In Perl, is there any reason to encapsulate a single variable in double quotes (no concatenation) ?

I often find this in the source of the program I am working on (w

5条回答
  •  臣服心动
    2021-01-12 12:01

    All this does is explicitly stringify the variables. In 99.9% of cases, it is a newbie error of some sort.

    There are things that may happen as a side effect of this calling style:

    my $foo = "1234";
    sub bar { $_[0] =~ s/2/two/ }
    print "Foo is $foo\n";
    bar( "$foo" );
    print "Foo is $foo\n";
    bar( $foo );
    print "Foo is $foo\n";
    

    Here, stringification created a copy and passed that to the subroutine, circumventing Perl's pass by reference semantics. It's generally considered to be bad manners to munge calling variables, so you are probably okay.

    You can also stringify an object or other value here. For example, undef stringifies to the empty string. Objects may specify arbitrary code to run when stringified. It is possible to have dual valued scalars that have distinct numerical and string values. This is a way to specify that you want the string form.

    There is also one deep spooky thing that could be going on. If you are working with XS code that looks at the flags that are set on scalar arguments to a function, stringifying the scalar is a straight forward way to say to perl, "Make me a nice clean new string value" with only stringy flags and no numeric flags.

    I am sure there are other odd exceptions to the 99.9% rule. These are a few. Before removing the quotes, take a second to check for weird crap like this. If you do happen upon a legit usage, please add a comment that identifies the quotes as a workable kludge, and give their reason for existence.

提交回复
热议问题