我有以下内容。
package A;
sub new {
my ($class) = @_;
my $self = { };
bless $self, $class;
return($self);
}
sub run() {
die "Task: ",__PACKAGE__, "requires a run method";
}
package B;
use A;
our @ISA = qw(A);
sub new {
my ($class) = @_;
my $self = { };
bless $self, $class;
return($self);
}
package C;
use A;
my @Tasks;
sub new {
my ($class) = @_;
my $self = { };
bless $self, $class;
return($self);
}
sub add{
my($self,$tempTask) = @_ ;
push(@Tasks,$tempTask);
$arraysize = @Tasks;
}
sub execute{
foreach my $obj (@Tasks)
{
$obj->run();
}
}
1;
脚本
#!/usr/local/bin/perl
use strict;
use C;
use B;
my $tb = new C();
my $task = new B();
$tb->add($task);
$tb->execute();
包B没有run方法,所以它默认为Package A run方法,这就是我想要的。此时我希望它打印出包B的名称(会有许多不同的包继承包A,但它没有。
目前,它使用__PACKAGE__
变量打印出套餐A.
任何帮助?
答案 0 :(得分:9)
对象是受祝福的引用。 __PACKAGE__
将始终等于当前包的名称。但ref( $object )
将为您提供对象类的名称。还有Scalar::Util::blessed
,对于非祝福的引用,它不会给你误报。
use Scalar::Util qw<blessed>;
my $obj = bless {}, 'A';
my $class = ref( {} ); # HASH
$class = blessed( {} ); # ''
$class = ref( $obj ); # A
$class = blessed( $obj ); # A
所以在你的特定情况下:
sub run() {
die "Task: " . ref( shift ) . "requires a run method";
}
答案 1 :(得分:2)
用此代替A::run
代码......
die "Task: ", ref shift, " requires a run method";
...将为您提供调用者对象所属的包(类)的名称(作为对象调用的每个方法的第一个参数是该对象本身,ref
将其类名返回为字符串)
答案 2 :(得分:0)
caller()是对此的一般答案,因为它可以为您提供所需的堆栈帧,包括包名称。