struct dynamic allocation error
Dechcaudron via Digitalmars-d
digitalmars-d at puremagic.com
Fri Sep 16 01:04:06 PDT 2016
On Thursday, 15 September 2016 at 21:21:12 UTC, Steven
Schveighoffer wrote:
> You need to destroy structs by passing them by reference.
> Passing a pointer just destroys the pointer.
>
> In this example, you can destroy what b points at (and call its
> destructor) via:
>
> destroy(*b);
>
> However, this will not fix the issue. This is because the
> memory block is not marked as being destroyed already (so it
> will run the dtor again). Class instances have a feature
> whereby when you call destroy it marks the memory block as
> already having the destructor run. Structs do not have this
> feature. Classes can afford to store extra metadata, structs
> cannot.
>
> So the true fix here is to avoid allocating in the destructor
> (which is a no-no for heap-allocated items). This may work, it
> may not:
>
> writefln("a is %s", a);
That makes it work. Thanks a lot! I thought the GC knew what had
already been destroyed, though. Thanks for letting me know that
only works for classes, that'll spare me a lot of trouble. Having
the destructor be run twice can be a bit of a hassle, but it's
nothing I can't find a workaround for.
Thank you all who replied! I'm sorry I chose the General room
instead of the Learn one. I really thought this was some kind of
bug (although it's pretty obvious it would've been reported by
someone else if it was).
More information about the Digitalmars-d
mailing list