Monks,
System Specs: Perl 5.10, Ubuntu 8.04, AMD 64x2, 4Gb RAM.
I am trying to understand why references that have gone out of scope are still hanging around.
Given the following code:
package Top;
sub new {
my $class = shift;
my $s = bless { }, $class;
$s->{bottom} = Bottom->new( $s );
return $s;
}
#=====================================
package Bottom;
sub new {
my ($class, $top) = @_;
return bless { top => $top }, $class;
}
#=====================================
package main;
use strict;
use warnings 'all';
use Devel::Cycle;
my $top = Top->new();
find_cycle( $top );
I get the following output:
Cycle (1):
$Top::A->{'bottom'} => \%Bottom::B
$Bottom::B->{'top'} => \%Top::A
If I change the code for package main to this:
local $| = 1;
for( 1...1_000_000 )
{
print "\r$_/1000000";
my $top = Top->new();
}
I burn through 200Mb of RAM in 42 seconds.
Using
Scalar::Util's
weaken function takes care of the RAM issue, but the weakened references disappear too soon (i.e. before I get a chance to use them!).
Example:
package Top;
use Scalar::Util 'weaken';
sub new {
my $class = shift;
my $s = bless { }, $class;
weaken($s);
$s->{bottom} = Bottom->new( $s );
return $s;
}
#=====================================
package Bottom;
use Scalar::Util 'weaken';
sub new {
my ($class, $top) = @_;
my $s = bless { top => $top }, $class;
weaken($s);
return $s;
}
#=====================================
package main;
use strict;
use warnings 'all';
my $top = Top->new();
my $bottom = $top->{bottom} or die "NO BOTTOM!";
Produces the output
NO BOTTOM!
Where can I look for a straightforward description of Perl, circular references, weaken, etc?
UPDATE: - Now it burns through 52Mb RAM in 26 seconds. Not sure if that's good or bad. I would expect Perl to recycle the RAM. Is that expectation wrong? Sure, 52Mb is better than the original number of 200Mb, but I would like to see no leakage at all.
Is it possible to do this without leaking memory?
Posts are HTML formatted. Put <p> </p> tags around your paragraphs. Put <code> </code> tags around your code and data!
Titles consisting of a single word are discouraged, and in most cases are disallowed outright.
Read Where should I post X? if you're not absolutely sure you're posting in the right place.
Please read these before you post! —
Posts may use any of the Perl Monks Approved HTML tags:
- a, abbr, b, big, blockquote, br, caption, center, col, colgroup, dd, del, details, div, dl, dt, em, font, h1, h2, h3, h4, h5, h6, hr, i, ins, li, ol, p, pre, readmore, small, span, spoiler, strike, strong, sub, summary, sup, table, tbody, td, tfoot, th, thead, tr, tt, u, ul, wbr
You may need to use entities for some characters, as follows. (Exception: Within code tags, you can put the characters literally.)
| |
For: |
|
Use: |
| & | | & |
| < | | < |
| > | | > |
| [ | | [ |
| ] | | ] |
Link using PerlMonks shortcuts! What shortcuts can I use for linking?
See Writeup Formatting Tips and other pages linked from there for more info.