For exactly this example, from my point of view, b.clean() is actually
using of the "b" property. Compiler, and I, don't know what '.clean()'
means and actually it is the same as
deinit {
b.doSomethingCool() // << shouldn't "b" created here to process your
request?
}
But probably I understand the problem you are trying to solve.
How to check if lazy property/variable was actually initialized, so you can
call its ".clean" only when it was really created and used. I.e. we just
don't need to call b.clean if "b" was not even called and so was not created.
Right now I can't find a way to check this, probably I'm missing something..
So the question is : how to check if b was or was not actually "created" :
(something like)
deinit {
if let b {
b.clean()
}
}
Anyone?
On 21.04.2016 13:27, Alexandr.moq via swift-evolution wrote:
Should SWIFT initialize a variable in deinit method if it has not been
initialized?
For example:
```swift
class A {
lazy var b = B()
deinit {
b.clean()
}
}
var a = A()
a.b.doSomething() //1: variable was created
a = A() //2: "clean" method was called for "b" variable
a = A() //3: instance of A from step 2 should killed and "deinit" method is called. In this method
"b" variable will be created, "clean" will be called and "b" will be killed. So, is it ok
or better if swift doesn’t create lazy variables in deinit if variable is not created yet
```
To be honest, I don’t know which topic I should use. Because I don’t know, it’s
propose, bug or something else.
_______________________________________________
swift-evolution mailing list
[email protected]
https://lists.swift.org/mailman/listinfo/swift-evolution
_______________________________________________
swift-evolution mailing list
[email protected]
https://lists.swift.org/mailman/listinfo/swift-evolution