Voldemort declarations inside structs with ctor initialization
Meta via Digitalmars-d
digitalmars-d at puremagic.com
Wed May 28 07:06:36 PDT 2014
On Wednesday, 28 May 2014 at 06:20:29 UTC, Idan Arye wrote:
> From what I know(don't know how it is implemented in D. I know
> it doesn't work that way in languages that emulate closures
> like C++ and Java) delegates don't "allocate a closure" -
> rather, they use a the callstack frame that was already
> allocated by the function as a closure. While it's true that
> they have to save a reference to that frame, there is no
> separately GCed memory for saving that reference - it's stored
> in the fat pointer together with the function pointer.
What I meant to say by "allocate a closure" is that variables in
the stack frame that the delegate has a pointer to are moved to
the heap when they go out of scope. I believe this implies GC
allocation, but I'm not 100% sure. If that *were* the case, then
you can see that marking the delegate as @nogc would mean that
code such as your example would fail to compile.
> The lambdas in my example don't allocate any memory when you
> *run* them.
I'm not completely sure whether they will or they won't... But
I'm pretty sure that this modified example will:
auto foo()
{
int a;
return () => is(typeof(a) : char);
}
void main()
{
writeln(foo()());
}
> At any rate, a delegate without a closure is either a
> `function`(which can be body-hashed without any problem) or a
> method(which doesn't need body-hashing), so having the @nogc
> restriction would be pointless even if @nogc prevented closures.
How is this restriction pointless if it means that delegates that
couldn't be hashed before due to their context can now be hashed?
More information about the Digitalmars-d
mailing list