Please read the question to the end as it seems to be the duplicate of many similar others but it is not. Most of the other questions use closures with let keyword to capture weak or unowned self before object init. I do not.
My code:
class Singleton : ObserverProtocol {
static let shared = Singleton()
private let obs : Observer = Observer.init()
private init() { self.obs.responder = self }
func observe(_ object : Any) {}
fileprivate class Observer : NSObject {
unowned var responder : ObserverProtocol!
func observe(_ obj : Any) {
self.responder.observe(obj)
}
}
}
fileprivate protocol ObserverProtocol : class {
func observe(_ object : Any)
}
When I try to compile I get an error highlighted on unowned var responder : ObserverProtocol!
'unowned' may only be applied to class and class-bound protocol types, not 'ObserverProtocol!'
If I change unowned to weak I can compile.
There is clearly some concept about unowned that I don't understand, so I would appreciate if someone could explain it to me.
P.S. I am aware of multiple questions similar to this:
UIView, CMDeviceMotionHandler : unowned may only be applied to class and class-bound protocol types
But I suppose this is not my case.
As you already know, unowned cannot be optional but weak may be nil at some point.
From what I understand, unowned variable is different from implicitly unwrapping optionals. Implicit unwrapping is for variables, which may be nil, but we already know this variable is not nil at the exact point of access. However, unowned variable can never be nil at any point.
Thus, you can't use unowned constant of type ObserverProtocol!. You need to get rid of !.
But if you do get rid of !, Observer needs an initializer that initializes responder.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With