假设我的课程非常简单:
class Box<T> { var Boxedobject:T init(object: T) { self.Boxedobject = object } }
我现在想要实现的是添加委托,它可以告诉我框中的值已经改变:
protocol BoxDelegate<T>: class { func valueInBoxChanged(Box: Box<T>) -> Void } class Box<T> { var Boxedobject: T { didSet { self.delegate?.valueInBoxChanged(self) } } weak var delegate: BoxDelegate<T>? init(object: T) { self.Boxedobject = object } }
此代码当然不起作用,因为我们没有通用委托.我可以使委托成为一个带闭包的结构,但它有点难看的解决方案.我应该如何在Swift中做这些事情?
解决方法
由于使用Swift的类型约束协议,您可能无法执行上面尝试执行的操作.你可以做的是在设置委托时创建一个闭包并稍后调用闭包.
这将使您的案例在某种程度上更简单,
protocol BoxDelegate: class { associatedtype T func valueInBoxChanged(Box: Box<T>) -> Void } class Box<T> { var notifyClosure: (Void -> Void)? var Boxedobject: T { didSet { self.notifyClosure?() } } func setBoxDelegate<M where M:BoxDelegate,M.T == T>(delegate: M) { notifyClosure = { delegate.valueInBoxChanged(self) } } init(object: T) { self.Boxedobject = object } }
因此,您不需要添加带有闭包的额外结构来使其工作.相反,您不会为BoxDelegate创建属性,而是创建一个方法来设置它并基于此创建一个闭包对象.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。