flipper has asked for the wisdom of the Perl Monks concerning the following question:
Hello monks,
I have a fairly large object framework, many parts of which use a singleton-type class, which contains quite a lot of state, and manages many other types of object.
When I wrote it, I intended that the first call to the constructor would return the "master" reference, subsequent calls would return weak references.
Unfortunately, I didn't test that this did what I expected, indeed perldoc Scalar::Util says
My problem (and a possible solution) is demonstrated in this snippet:Note that if you take a copy of a scalar with a weakened reference, th +e copy will be a strong reference. my $var; my $foo = \$var; weaken($foo); # Make $foo a weak reference my $bar = $foo; # $bar is now a strong referen +ce
/usr/bin/perl use strict; use Scalar::Util qw/weaken isweak/; my $foo = {}; my $bar = returnweak(); print "returnweak isweak - ".(isweak($bar)? "yes":"no")." - '$bar'\n"; weakenbyref(\$bar); print "weakenbyref isweak - ".(isweak($bar)? "yes":"no")." - '$bar'\n" +; sub returnweak { my $ret = $foo; weaken($ret); return $ret; } sub weakenbyref { my $arg = shift; weaken($$arg = $foo); return; }
which outputs:
returnweak isweak - no - 'HASH(0x606df0)' weakenbyref isweak - yes - 'HASH(0x606df0)'
However passing a reference to the scalar which will contain the objectref is an unusual constructor, and would require changes to all callers, which I'd like to avoid if possible.
Is there a solution which does what I want (create a really weak reference which when copied/assigned, remains weak), and doesn't require a change in all calling code? Something like Scalar::Util::cripple :-)Thanks
|
|---|
| Replies are listed 'Best First'. | |
|---|---|
|
Re: return weak reference
by ikegami (Patriarch) on Sep 01, 2010 at 15:39 UTC | |
by flipper (Beadle) on Sep 02, 2010 at 09:52 UTC | |
by ikegami (Patriarch) on Sep 02, 2010 at 15:32 UTC | |
|
Re: return weak reference
by chromatic (Archbishop) on Sep 01, 2010 at 22:04 UTC | |
by flipper (Beadle) on Sep 02, 2010 at 10:26 UTC |