You set $self to be a reference to an anonymous hash, then set $self{'date'} to the result of the date system call. What perl does is create a new hash, %self, and fills its 'date' key with that result. Since all variables are globals by default, this %self (not to be confused with $self) will be the same for all methods that attempt to access it. Hence, all calls to the 'get' method of TEST will return the same value regardless of instance, since the method references the global hash %self, not the private instance variable $self.sub new { my $class = shift; my $self = {}; bless ($self, $class); $self{'date'} = `date`; warn "In TEST->new, created object $self, with date $self{'date'}" +; return $self; }
So use $self->{'date'} instead of $self{'date'}, and all will be well. Also, make it a habit to 'use strict' at all times, as it will catch all sorts of bugs like this.
In reply to Re: Why, when my object creates another object and passes it back, does it not work?
by ton
in thread Why, when my object creates another object and passes it back, does it not work?
by bobtfish
| For: | Use: | ||
| & | & | ||
| < | < | ||
| > | > | ||
| [ | [ | ||
| ] | ] |