in reply to TIMTOWTDI vs. ithreads

I don't think that's a good idea in perl. If all data would be shared, than perl would have to lock any piece of data it reads or writes, and that would be a major speed penalty (and maybe memory too, I'm not sure). Also if data are shared than the memory management has to be shared too, because any thread might have to free any data (when it finds that the reference count has dropped to zero) and that would also be a minor slowdown.

Replies are listed 'Best First'.
Re^2: TIMTOWTDI vs. ithreads
by nothingmuch (Priest) on Sep 14, 2004 at 17:43 UTC
    How is this avoided with interpreter threads? They can, after all, share data... I reckon that since it's a special case it might be handled specially, whilst other data is not?

    Furthermore, today starting a thread is an enourmous performance penalty, because all non shared data is copied. Unlike forking, where we have copy-on-write (for the curious- it's very efficient, because the kernel simply marks all memory pages as readonly, causing write operations to raise an exception from the MMU, to which the kernel responds to making a new copy of the page which the writing process can work on), there is no optimisation of the process. The main advantage I'm looking for in threads is to gain performance due to concurrency on SMP platforms, for small tasks. Starting a thread needs to be cheap for this to be effective. I think a tradeoff of some continuous speed penalty for an efficient startup time, should at least be a choice.

    I'll go looking for some reading material, but I'm sick and too tired to concentrate for any reasonable length of time, so I doubt I can introduce any worthwhile discussion to this thread.

    -nuffin
    zz zZ Z Z #!perl

      When you use ithreads properly, you create the threads soon, when there are only very few data in the heap, and you use as few shared data as possible. When ithreads is used this way, it should be reasonably fast.

      This means that the ithreads model is not ideal for some tasks you could normally do with threads. Ithreads are, however, very good for tasks where the threads do almost independent work, such as fork emulation or servers handling multiple connections. It is not suited for other tasks, such as tasks with heavy paralel computation imo.

      Thus, I aggree with your original post in that ithreads might not always be what you want.

      I do not know about any high level language supporting a thread model similar to for example pthreads, probably because that would make the interpreter unstable when you do not uses locks properly (5005Threads were like that iirc). If you need such threads, you migt want to look at other languages than Perl. Ruby has continuation-based threads, that means of course that it uses only one cpu at a time.