digitalmars.D.learn - Are structs saved in multi-thread delegate call?
I have something along this way:
struct json_value
{
..
}
function DoDirSearch(..)
{
immutable json_value cbk = json_value(prms.argv[3]);
assert(cbk != json_value.init); // OK, pass
import core.thread;
new Thread({
assert(cbk != json_value.init); // FAIL!
}).start();
}
the problem is, my struct value is not saved in the spawned tread
context, so this assert fails while at the start it passed:
assert(cbk != json_value.init);
Apr 22 2016
mmm, I figured the problem, but don't know how to solve it.
my struct has a destructor which clears itself:
struct json_value
{
~this() { .ValueClear(&data); }
}
so how I can I put a struct in the heap? (not in the stack, as is
the default..)
Apr 22 2016
On Saturday, 23 April 2016 at 01:11:49 UTC, Ramon wrote:
mmm, I figured the problem, but don't know how to solve it.
my struct has a destructor which clears itself:
struct json_value
{
~this() { .ValueClear(&data); }
}
so how I can I put a struct in the heap? (not in the stack, as
is the default..)
new or make with arg or new or make then opAssign or this(this).
but have you tried
__ghsared immutable json_value cbk = json_value(prms.argv[3]);
? without __gshared cbk might be on the TLS. (see with -vtls
switch on DMD)
Apr 22 2016
On 23.04.2016 03:11, Ramon wrote:
mmm, I figured the problem, but don't know how to solve it.
my struct has a destructor which clears itself:
struct json_value
{
~this() { .ValueClear(&data); }
}
So the struct is destroyed at the end of DoDirSearch, despite there
being a closure for it. Is the compiler doing the right thing here?
Shouldn't the struct be considered alive until the closure gets garbage
collected?
Apr 22 2016
On 23.04.2016 07:35, ag0aep6g wrote:So the struct is destroyed at the end of DoDirSearch, despite there being a closure for it. Is the compiler doing the right thing here? Shouldn't the struct be considered alive until the closure gets garbage collected?I've filed an issue: https://issues.dlang.org/show_bug.cgi?id=15952
Apr 23 2016









ed <ed ed.de> 