Your property has a custom setter, and when you call a = 2
in the init
block, that setter's code will run.
That code could be arbitrarily complex, and the compiler can't know for sure whether it will end up setting the value of the backing field of the property or not. In your code example, it would set the backing field, and your property would be in a valid state.
However, you could also have a custom setter such as this one:
private var a: Int
set(value) {
if (value > 0) {
field = value
}
}
Calling this in an init
block would not necessarily would be enough, as it might leave the property in an uninitialized state.
To prevent this, the compiler asks you to set a value to the property at its declaration instead when using custom setters.
与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…