Well, let's take a look. $self within first_name is scoped locally. It is set to a blessed ref of class Test which is passed to first_name as a parameter. On the next line, you change $self to an anonymous hash with the values contained within @_. In the process, you lose the blessed ref and thus are no longer working with your object. Therefore, you lose your data once you leave the sub. Try something like this instead:
sub first_name { my $self = shift; $self->{'first'} = shift; return "First Name: $self->{first}\n"; }
And call it like this:
$test->first_name("bill");
Hope this helps. Note that you need to do this to last_name as well.
antirice
The first rule of Perl club is - use Perl
The ith rule of Perl club is - follow rule i - 1 for i > 1
In reply to Re: Keeping data in an object
by antirice
in thread Keeping data in an object
by AzaBat
| For: | Use: | ||
| & | & | ||
| < | < | ||
| > | > | ||
| [ | [ | ||
| ] | ] |