微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Perl子例程中的变量不会释放内存

我有一个关于子程序中的变量何时以及如何释放内存的问题.该脚本是一个例子:

#!perl/bin/per
use strict;
sub A{
    my $x= shift;
    return ([$x]);
}
for my $i (1..10){
    my $ref= &A($i);## the input changes in each round
    my $ref2= &A(9);## the input is fixed in each round
    print "$ref\t";
    print "$ref2\n";
}

并且屏幕上的输出是:

ARRAY(0x996e98) ARRAY(0x9b50c8)
ARRAY(0x996e98) ARRAY(0x9b50c8)
ARRAY(0x996e98) ARRAY(0x9b50c8)
ARRAY(0x996e98) ARRAY(0x9b50c8)
ARRAY(0x996e98) ARRAY(0x9b50c8)
ARRAY(0x996e98) ARRAY(0x9b50c8)
ARRAY(0x996e98) ARRAY(0x9b50c8)
ARRAY(0x996e98) ARRAY(0x9b50c8)
ARRAY(0x996e98) ARRAY(0x9b50c8)
ARRAY(0x996e98) ARRAY(0x9b50c8)

我预计在子程序A被调用多次时应该更改引用,但无论何时更改输入,输出引用都是固定的.这种现象是否可以推断,在整个脚本结束之前,子程序中变量占用的内存永远不会被释放?否则,我的结果是不寻常的?

解决方法

>对A($i)的调用在perl认为方便可用的任何位置分配新的arrayref.
>该数组引用返回到您的循环体,并存储在一个词法范围到该循环体的变量中.
>在循环的底部,变量超出范围,并且由于没有其他内容引用该arrayref,因此释放了arrayref.
>因此,以前保存arrayref的内存位置再次方便可用,并在下次需要时重新使用…在下次调用A()时
>转到1

如果阻止数组被释放,您将看到在不同地址创建的新数组.

my @a;
for my $i (1..10){
    my $ref= &A($i);## the input changes in each round
    my $ref2= &A(9);## the input is fixed in each round
    print "$ref\t";
    print "$ref2\n";
    push @a,$ref,$ref2;
}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐