Beefy Boxes and Bandwidth Generously Provided by pair Networks
No such thing as a small change

Re^6: Threads and fork and CLONE, oh my!

by demerphq (Chancellor)
on Nov 15, 2005 at 14:49 UTC ( #508626=note: print w/replies, xml ) Need Help??

in reply to Re^5: Threads and fork and CLONE, oh my!
in thread Threads and fork and CLONE, oh my!

Even more efficient would be to write a custom hash loading routine in XS that a) extracts the refaddr automatically, and b) uses the binary representation of the address as the key for the hash lookup/storage. Currently when you use $hash{0+$self}=$foo you are doing itoa() on the address, then using the resulting string for the hash key. If the addresses binary representation was used as the key they keys would be fixed length, and would not require the itoa() step, and would be much faster. I imagine this would about 4-8 lines of XS code and would be drammatically faster than using $hash{0+$self}. Ie I can imagine an API like:

ref_key_store(%hash,$ref,$value); my $val=ref_key_fetch(%hash,$ref);

Log In?

What's my password?
Create A New User
Node Status?
node history
Node Type: note [id://508626]
and all is quiet...

How do I use this? | Other CB clients
Other Users?
Others scrutinizing the Monastery: (5)
As of 2017-10-16 22:43 GMT
Find Nodes?
    Voting Booth?
    My fridge is mostly full of:

    Results (217 votes). Check out past polls.