http://www.perlmonks.org?node_id=1007022


in reply to perl oop concept

This looks like OOP code:

package a; sub new { my $class = shift; my $self = {}; bless $self,$class; return $self; } my $obj = new a ();

However, the last line there is generally considered poor style. Try:

my $obj = "a"->new();

But these lines seem to bear no relation to OOP:

$obj ->{$self}{avalue}=10; print $obj->{$self}{avalue};

Try something like this:

{ package a; sub new { my $class = shift; my $self = {}; bless $self,$class; return $self; } sub avalue { my $self = shift; $self->{avalue} = shift if @_; return $self->{avalue}; } } my $obj = "a"->new(); $obj->avalue(10); # set print $obj->avalue, "\n"; # get

That should give you an idea how OOP works. That said, I'd recommend using Moose or Moo as a way of reducing repetitive OOP code...

{ package a; use Moo; has avalue => (is => 'rw'); } my $obj = "a"->new(); $obj->avalue(10); # set print $obj->avalue, "\n"; # get
perl -E'sub Monkey::do{say$_,for@_,do{($monkey=[caller(0)]->[3])=~s{::}{ }and$monkey}}"Monkey say"->Monkey::do'