Beefy Boxes and Bandwidth Generously Provided by pair Networks
Welcome to the Monastery

Re: Efficient shared memory - possible? how??

by JavaFan (Canon)
on Feb 20, 2012 at 12:01 UTC ( #955055=note: print w/replies, xml ) Need Help??

in reply to Efficient shared memory - possible? how??

Shared memory is just that, a piece of memory that is shared between processes. There's no build in support to share Perl variables.

You could make a tied hash, which will store its values in shared memory. Beaware though that when you initiate a piece of shared memory, you will have to supply a size. If you're sticking to storing numerical values, then it's easy. 4 or 8 bytes will do. If you want to share strings, and have them mutable as in Perl, you will have to implement your own double pointer trick (as Perl does).

Optimizing memory is hard work if your choice of tool is Perl, because Perl usually picks speed over memory when having a choice, and because there's a lot of hidden stuff going on around your back.

Using threads make it easier to share variables, but Perl threads copy a priory every variable that isn't shared, unlike (Unix) forks which uses copy-on-write. Threads may be the better solution for you, but that's something only you can find out, but doing actual measurement.

  • Comment on Re: Efficient shared memory - possible? how??

Log In?

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

How do I use this? | Other CB clients
Other Users?
Others musing on the Monastery: (3)
As of 2023-02-08 03:47 GMT
Find Nodes?
    Voting Booth?
    I prefer not to run the latest version of Perl because:

    Results (40 votes). Check out past polls.