我正在尝试创建一个通用的 WeakReference
类型,以便我可以将其放入数组中(最终创建一个通用的弱引用数组类型)。
目前为止还不错,但以下代码:
class WeakReference<ElementType: AnyObject> {
weak var element: ElementType?
init(_ element: ElementType) {
self.element = element
}
}
protocol Element: AnyObject {}
class WeakElementHolder {
var weakElements: [WeakReference<Element>] = []
}
导致此编译器错误:
WeakReference.swift:12:21: error: 'WeakReference' requires that 'Element' be a class type
var weakElements: [WeakReference<Element>] = []
^
WeakReference.swift:1:7: note: requirement specified as 'ElementType' : 'AnyObject' [with ElementType = Element]
class WeakReference<ElementType: AnyObject> {
^
这很奇怪,因为该协议明确需要一个类 (AnyObject
)。
如果我省略泛型,一切都能正常工作,这很奇怪:
protocol Element: AnyObject {}
class WeakElementReference {
weak var element: Element?
init(_ element: Element) {
self.element = element
}
}
class WeakElementHolder {
var weakElements: [WeakElementReference] = []
}
我搜索后发现了这个问题,但它没有得到真正的回答。
是否有一种解决方法仍然可以实现一个弱引用的通用数组,并与类约束协议一起使用?
更新:
我的具体用例是存储一个观察者列表,当发生某些事情时,要通知这些观察者:
protocol Observer: AnyObject {
func notify()
}
class WeakReference<ElementType: AnyObject> {
weak var element: ElementType?
init(_ element: ElementType) {
self.element = element
}
}
class WeakArray<ElementType: AnyObject> {
var content: [WeakReference<ElementType>] = []
}
class Observable {
var observers: WeakArray<Observer>()
func notifyAllObservers() {
// call notify() on all observers here
}
}
这些观察者可以是许多不同的具体类型。
更多澄清:
不仅有一个Observer
协议,还有许多毫无共同之处的协议,这就是为什么我想要首先将其变成通用的原因。