如果我将哈希引用定义为:
my %hash1=(
"a" => 1,
"b" => 2,
"c" => {
"d" => 4,
"e" => 5
}
);
my $r_hash1 = \%hash1;
将使用:
$r_hash1->{c}=();
要清除%hash1 {c}中的键以便重复使用吗?
如果是这样,我也想知道我是否有:
my %hash1=(
"a" => 1,
"b" => 2
);
my %hash2=(
"d" => 4,
"e" => 5
);
my $r_hash1 = \%hash1;
my $r_hash2 = \%hash2;
$r_hash1->{"c"} = $r_hash2;
是否使用:
$r_hash1->{c}=();
释放%hash2使用的内存以供重用,因为它肯定必须在哈希上下文中使用:
%$r_hash1->{c}
但这会在哈希上下文中查看$ r_hash1,而不是$ r_hash1-> {c}的内容。
感谢。
答案 0 :(得分:5)
如果要清空嵌套哈希(但仍然存在哈希),则需要首先取消引用它:
%{ $r_hash1->{c} } = ( );
或者,您可以在其位置分配一个空的hashref:
$r_hash1->{c} = { };
在您的第二个示例中,如果您设置$r_hash1->{c} = $r_hash2
,然后使用%{ $r_hash1->{c} } = ( )
清除它,%hash2
中的内容将清除。这是因为您要取消引用$r_hash1->{c}
,这是$r_hash2
的副本,它是对%hash2
的引用。
这是一个简单的程序,用于演示结果:
perl -MData::Dumper -E '%h1 = ( a => 1, b => 2 ); %h2 = ( d => 4, e => 5 ); $h1{c} = \%h2; say Dumper \%h1; %{ $h1{c} } = ( ); say Dumper \%h1; say Dumper \%h2'
$VAR1 = {
'c' => {
'e' => 5,
'd' => 4
},
'a' => 1,
'b' => 2
};
$VAR1 = {
'c' => {},
'a' => 1,
'b' => 2
};
$VAR1 = {};
这略有缩写(我没有打扰中间命名引用。)第一个转储显示%h1
及其对%h2
的引用。在取消引用引用并将其清除后,第二个转储显示%h1
。第三个转储在清除后显示原始%h2
。
另一方面,如果您使用$h1{c} = { }
,原始%h2
将不受影响,因为您只是替换$h1{c}
的值。它最初是%h2
的引用;现在它是对新匿名哈希的引用。