Beefy Boxes and Bandwidth Generously Provided by pair Networks
The stupid question is the question not asked
 
PerlMonks  

Re^3: Memory overhead of blessed hashes

by jcb (Parson)
on Feb 10, 2021 at 00:06 UTC ( [id://11128159]=note: print w/replies, xml ) Need Help??


in reply to Re^2: Memory overhead of blessed hashes
in thread Memory overhead of blessed hashes

I know that method lookups are cached, but I am quite certain (from the last time I read the documentation) that that cache is associated with the package STASH, rather than each object, since it logically applies to the class (package) and is shared between all objects of that class.

I would have to dig into the code to be sure, but the memory overhead for bless appears to be very minimal — once an SV has been upgraded high enough to carry any kind of magic, it also has a STASH pointer, and AV and HV structures are complex enough that they always have those fields.

Arrays in Perl do have considerably smaller overhead than hashes, although not a factor of 10. If you have a large number of some class of object, enough to cause memory usage problems, changing the internal representation to arrays and using constant to name the fields is likely to help. If encapsulation has been respected, this will require no changes outside of the object's implementation class.

Replies are listed 'Best First'.
Re^4: Memory overhead of blessed hashes
by LanX (Saint) on Feb 10, 2021 at 00:55 UTC
    > I know that method lookups are cached,

    I remembered hearing people talking about this. That was the only possible theory left.

    > but I am quite certain (from the last time I read the documentation) that that cache is associated with the package STASH, rather than each object, since it logically applies to the class (package) and is shared between all objects of that class.

    Cool, that's what I needed to know! :)

    > Arrays in Perl do have considerably smaller overhead than hashes, although not a factor of 10.

    I did some tests for different sizes, yes it's not that dramatic - a 50% win is a very optimistic scenario.°

    > changing the internal representation to arrays and using constant to name the fields is likely to help.

    Well it's not my project anyway and some of my colleagues have weird strategies when it comes to optimization.

    Personally I'm thinking rather in O() categories, and 50% best case wouldn't convince me to refactor.

    I'd rather give Toby's suggestion for Insight-Out-Objects a shot.

    Cheers Rolf
    (addicted to the Perl Programming Language :)
    Wikisyntax for the Monastery

    °) Though I'm not too sure if I got the Powershell and Windows right, since all the spared "keys" should cause a bigger impact. Will need to dig deeper. :)

Re^4: Memory overhead of blessed hashes
by ikegami (Patriarch) on Feb 11, 2021 at 06:28 UTC

    but I am quite certain (from the last time I read the documentation) that that cache is associated with the package STASH, rather than each object, since it logically applies to the class (package) and is shared between all objects of that class.

    That is the case.

    $ perl -M5.010 -e' package Foo { sub f { } } package Bar { our @ISA = "Foo"; } say for keys %{ $::{"Bar::"} }; say "---"; Bar->f(); say for keys %{ $::{"Bar::"} }; ' ISA --- ISA f

    Seeking work! You can reach me at ikegami@adaelis.com

Log In?
Username:
Password:

What's my password?
Create A New User
Domain Nodelet?
Node Status?
node history
Node Type: note [id://11128159]
help
Chatterbox?
and the web crawler heard nothing...

How do I use this?Last hourOther CB clients
Other Users?
Others having an uproarious good time at the Monastery: (7)
As of 2024-04-19 10:09 GMT
Sections?
Information?
Find Nodes?
Leftovers?
    Voting Booth?

    No recent polls found