Joh*_*Doe 4 perl pointers reference
在Perl中,如果我创建两个对数组元素的引用,则两个指针是相等的.
my $ref1 = \$array[0];
my $ref2 = \$array[0];
print "$ref1\n$ref2";
Run Code Online (Sandbox Code Playgroud)
这同样适用于对存储字符串的变量的两个引用,这些指针是相等的.
如果我创建两个存储相等字符串的变量,则引用不相等.
为什么他们不平等?相同的数据存储在不同的地方?
Perl是否引用变量而不是内存位置?
在Java中,正如您在此处看到的,四个相等的字符串指的是相同的内存位置.
有人可以解释一下吗?
如果您对一个变量进行多次引用,则所有变量都将指向相同的内存位置.
my $foo = 'foo';
my $ref1 = \$foo;
my $ref2 = \$foo;
say $ref1;
say $ref2;
Run Code Online (Sandbox Code Playgroud)
后面的值$ref1和$ref2是相同的,因为它们都指向同一个变量.
SCALAR(0x171f7b0)
SCALAR(0x171f7b0)
Run Code Online (Sandbox Code Playgroud)
如果将字符串(不是包含字符串的同一变量)分配给两个新变量,然后为这些变量引用,则它们将是不同的.
my $foo = 'foo';
my $bar = 'bar';
my $ref1 = \$foo;
my $ref2 = \$bar;
say $ref1;
say $ref2;
Run Code Online (Sandbox Code Playgroud)
这里$ref1和$ref2它们不一样,因为它们是对两个不同变量的引用.
SCALAR(0x20947b0)
SCALAR(0x2094678)
Run Code Online (Sandbox Code Playgroud)
两个变量保持相等的值并不重要.
my $ref1 = \'foo';
my $ref2 = \'foo';
say $ref1;
say $ref2;
Run Code Online (Sandbox Code Playgroud)
如果您直接接受对值的引用而不将其首先放入另一个变量,则同样如此.
SCALAR(0x1322528)
SCALAR(0x12ee6f0)
Run Code Online (Sandbox Code Playgroud)
Perl在内部处理内存,但它不像它有一个包含每个可能字符串的表,并且无论何时创建引用,它只使用该内存地址.
在Java中,字符串是对象.Java知道可用的对象.定义字符串时,它会生成一个对象.Perl的情况并非如此.字符串和数字只是值,当您使用它们时它们会被放入内存中.
Perl所做的是跟踪其引用.它将通过删除未使用的值来释放内存,但前提是这些值不再存在于正在运行的程序中的其他位置.这称为引用计数.
您可以在perlref中阅读有关引用的信息.在Mannings的Damian Conway 的" 面向对象的Perl "一书中,还有一个很好的解释.