Which Multithreading Solution?
Adam Wilson
flyboynw at gmail.com
Sun Mar 4 20:25:56 UTC 2018
On 3/4/18 11:31, Drew Phil wrote:
> Hey there!
>
> I'm trying to figure out which of D's many multithreading options to use
> for my application. I'm making a game that runs at 60 frames per second
> that can also run user-made Lua scripts. I would like to have the Lua
> scripts run in a separate thread so they can't delay frames if there's a
> lot of work to do in a burst, but I also need it to be able to update
> and read from the thread where everything else is.
>
> I don't think message passing is going to cut it because the Lua thread
> is going to need to be able to request to set a value in D on one line,
> and then request that value back on the next line, and that value needs
> to be updated at that point, not at the end. I've been marking things as
> __gshared to get them working, but I think that just makes a copy on all
> threads, which seems pretty excessive when mostly the Lua will just be
> reading values, and occasionally calling a function in D to change some
> values.
>
> I think I should try to do some kind of lock thing, but I'm not really
> sure how that works. If someone could advise me on what tact I should
> take, that would be very helpful.
>
> Thanks!
core.thread is probably your best bet in the long-term. std.concurrency
could actually be used though, just call receive() immediately after
send(). However, the performance of this may not be what you want. My
recommendation would be to use std.concurrency to get the logic correct
first, then worry about perf. And using std.concurrency will get some of
the basic concepts (ex: immutable/shared) right that will port over the
regular threads.
--
Adam Wilson
IRC: LightBender
import quiet.dlang.dev;
More information about the Digitalmars-d-learn
mailing list