[lnkForumImage]
TotalShareware - Download Free Software

Confronta i prezzi di migliaia di prodotti.
Asp Forum
 Home | Login | Register | Search 


 

Forums >

comp.lang.ruby

Accessing ruby 1.9 interpreter from other threads

Bill Kelly

8/28/2007 10:33:00 AM

Hi,

I seem to recall hearing 1.9 is using native threads now.

If so, does that mean it's now safe for multiple OS threads
to call into the 1.9 ruby interpreter, and eval or execute
ruby code? (I'm assuming some sort of interpreter lock would
need to be grabbed.)


Thanks,

Bill



4 Answers

Nobuyoshi Nakada

8/29/2007 7:20:00 AM

0

Hi,

At Tue, 28 Aug 2007 19:33:02 +0900,
Bill Kelly wrote in [ruby-talk:266532]:
> I seem to recall hearing 1.9 is using native threads now.
>
> If so, does that mean it's now safe for multiple OS threads
> to call into the 1.9 ruby interpreter, and eval or execute
> ruby code? (I'm assuming some sort of interpreter lock would
> need to be grabbed.)

And to bind calling native thread a ruby thread. But still not
provided now.

--
Nobu Nakada

Charles Oliver Nutter

8/29/2007 10:16:00 AM

0

Nobuyoshi Nakada wrote:
> Hi,
>
> At Tue, 28 Aug 2007 19:33:02 +0900,
> Bill Kelly wrote in [ruby-talk:266532]:
>> I seem to recall hearing 1.9 is using native threads now.
>>
>> If so, does that mean it's now safe for multiple OS threads
>> to call into the 1.9 ruby interpreter, and eval or execute
>> ruby code? (I'm assuming some sort of interpreter lock would
>> need to be grabbed.)
>
> And to bind calling native thread a ruby thread. But still not
> provided now.

A similar mechanism is used in JRuby to "adopt" incoming Java threads as
Ruby threads, allowing them to participate in thread events like kill
and raise. But there's nothing explicit about it; threads that haven't
been adopted are adopted automatically. Can't this be done automatically?

- Charlie

Nobuyoshi Nakada

9/5/2007 7:29:00 AM

0

Hi,

At Wed, 29 Aug 2007 19:16:00 +0900,
Charles Oliver Nutter wrote in [ruby-talk:266657]:
> A similar mechanism is used in JRuby to "adopt" incoming Java threads as
> Ruby threads, allowing them to participate in thread events like kill
> and raise. But there's nothing explicit about it; threads that haven't
> been adopted are adopted automatically. Can't this be done automatically?

Does that "adopt" occur in any call to ruby? Isn't it
performance overhead?

--
Nobu Nakada

Charles Oliver Nutter

9/5/2007 6:43:00 PM

0

Nobuyoshi Nakada wrote:
> Hi,
>
> At Wed, 29 Aug 2007 19:16:00 +0900,
> Charles Oliver Nutter wrote in [ruby-talk:266657]:
>> A similar mechanism is used in JRuby to "adopt" incoming Java threads as
>> Ruby threads, allowing them to participate in thread events like kill
>> and raise. But there's nothing explicit about it; threads that haven't
>> been adopted are adopted automatically. Can't this be done automatically?
>
> Does that "adopt" occur in any call to ruby? Isn't it
> performance overhead?

Not really, if the thread hasn't been adopted it just constructs a new
Ruby thread to wrap it and a "thread context" to govern frames, scopes,
etc for Ruby execution. That's a one-time hit that only happens the
first time a normal Java thread enters Ruby code. From then on it
largely just looks like any other Ruby thread.

- Charlie