我想在我的一个二进制函数中使用$a和$b变量,就像在sort {$a< => $b}(1,2,3),但我不知道为什么代码像
#!/usr/bin/env perl use strict; use warnings; Foo::Bar(sub { $a + $b }); package Foo; sub Bar { my ($function) = @_; for my $i (1,3) { local ($a,$b) = ($i,$i); print $function->() . "\n"; } }
不行而
#!/usr/bin/env perl use strict; use warnings; Foo::Bar(sub { $_ }); package Foo; sub Bar { my ($function) = @_; for my $i (1,3) { local $_ = $i; print $function->() . "\n"; } }
工作正常.
我究竟做错了什么?
解决方法
$a和$b是特殊的包变量.您正在从主包中调用Foo :: Bar,因此您需要设置$main :: a和$main :: b才能使其正常工作.您可以使用
caller
获取呼叫包的名称.这应该工作:
#!/usr/bin/env perl use strict; use warnings; Foo::Bar(sub { $a + $b }); package Foo; sub Bar { my ($function) = @_; my $pkg = caller; for my $i (1,3) { no strict 'refs'; local *{ $pkg . '::a' } = \$i; local *{ $pkg . '::b' } = \$i; print $function->() . "\n"; } }