Beefy Boxes and Bandwidth Generously Provided by pair Networks
Syntactic Confectionery Delight

Re^4: Class::Std::Fast cache and threads

by Boldra (Deacon)
on Oct 12, 2010 at 11:22 UTC ( #864808=note: print w/replies, xml ) Need Help??

in reply to Re^3: Class::Std::Fast cache and threads
in thread Class::Std::Fast cache and threads

Thanks for the answer, but I dislike this due to the program flow it will force me into. It will look something like this:
  1. load most libraries
  2. create threads and put them to sleep
  3. load the soap libraries
  4. do some soap calls
  5. do some other things
  6. wake and use the threads, (passing arguments via a share I created earlier?)
  7. do some more soap calls
Which I don't trust to be very maintainable.
  • Comment on Re^4: Class::Std::Fast cache and threads

Replies are listed 'Best First'.
Re^5: Class::Std::Fast cache and threads
by BrowserUk (Pope) on Oct 12, 2010 at 11:53 UTC
    wake and use the threads, (passing arguments via a share I created earlier?)

    The 'normal' thing to do is to have your work threads block reading from a que. Your main thread then instigates the worker to do something by posting something to that queue.

    This obviously doesn't fit with every use case, but without knowledge of your use case it is hard to advise?

    The problem you describe arises because of the ithreads mechanism of cloning everything currently existing into each newly spawned thread. This is a way of avoiding the problem by avoiding the class(s) giving you problems from being cloned.

    There are other approaches, some of which were suggested by anonymonk above--like fixing the module.

    One not mentioned so far is to create a 'thread factory thread'. You start a thread early in the program--before loading most other modules--who's sole purpose is to spawn other threads. Because any threads spawned by the factory thread are clones of it, they will not have anything cloned into them that was not loaded when the factory thread was spawned.

    The problem with this is that I haven't yet found a way to implement a clean interface for it.

    If your croak override works, I'd say go for it. But the whole concept of inside-out (flyweight) objects and threads are pretty incompatible.

    Examine what is said, not who speaks -- Silence betokens consent -- Love the truth but pardon error.
    "Science is about questioning the status quo. Questioning authority".
    In the absence of evidence, opinion is indistinguishable from prejudice.

Log In?

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

How do I use this? | Other CB clients
Other Users?
Others wandering the Monastery: (11)
As of 2018-06-25 10:32 GMT
Find Nodes?
    Voting Booth?
    Should cpanminus be part of the standard Perl release?

    Results (126 votes). Check out past polls.