On Apr 27, 11 19:42, Mariusz Gliwiński wrote:
Hello, I'm next person, which isn't necessarily happy about delete operator deprecation.
I don't get the recent resistant against deletion of 'delete' which has been decided months before (before TDPL). The operator is removed does not mean the destructor can't be invoked at all.
Because constructors / destructors are frequently used not only for application controlled memory management, how would You implement something like following code without delete operator?
Use 'scoped' or a 'struct' if you want to constrain 's1' in a scope import std.typecons; void main(string[] args) { auto res = new Resource(); { auto s1 = scoped!FirstSystem(res); } auto s2 = new SecondSystem(res); } <or> void main(string[] args) { auto res = new Resource(); { auto s1 = FirstSystem(res); } auto s2 = new SecondSystem(res); } struct FirstSystem { private Resource res; this(Resource res) { this.res = res; res.referenced = true; } ~this() { res.referenced=false; } } class Resource { public bool referenced; } Or use 'clear' to replace 'delete' as told in many posts already void main(string[] args) { auto res = new Resource(); auto s1 = new FirstSystem(res); // many miles away clear(s1); auto s2 = new SecondSystem(res); }
<code>
[snip]
</code> Next questions would be: * Are you going to drop destructor as well, or maybe destructor is going to be confusing feature with non-deterministic behaviour? (How would i know when heap allocated Socket will be destructed -> when connection will be closed -> if my system gonna be DoS'ed?)
The allocators (http://d-programming-language.org/class.html#allocators) and deallocators (http://d-programming-language.org/class.html#deallocators) are going away. The destructors (http://d-programming-language.org/class.html#destructors) are not.
* Are you going to stop supporting object oriented programming? (Well, if *deterministic* resource managing can be only inside function, and not object boundaries, that's my conclusion).
'delete' only governs memory management. Since when deterministic *memory* management becomes a requirement of OOP? If you need deterministic resource management, you could use the dispose pattern. Java doesn't have a 'delete' operator either, that doesn't make Java a non-OOP language.
And finally, don't get me wrong. I'm just caricaturizing my current worries about the language, and if I'm missing something - please hint me what. Sincerely, Mariusz Gliwiński