我上了简单的课:
class Values<T> {
let new: T
let old: T?
init(new: T, old: T? = nil) {
self.new = new
self.old = old
}
func changed<TProp: AnyObject>(_ getter: (T) -> TProp) -> Bool {
return old == nil || !(getter(old!) === getter(new))
}
func changed<TProp: Equatable>(_ getter: (T) -> TProp) -> Bool {
return old == nil || !(getter(old!) == getter(new))
}
}
将其用作Values<ChartViewModelData?>
时(其中ChartViewModelData是一个类),当old嵌套可选时,我遇到了问题-它既为nil又不等于nil:
因此更改这样的功能没有帮助:
return old == nil || old! == nil || !(getter(old!) === getter(new))
nil不应该传递给getter函数,而且我也不知道如何实现。
复制:
class PropClass {}
class TestClass {
var someProp = PropClass()
}
let values = Values<TestClass?>(new: TestClass(), old: Optional<Optional<TestClass>>(nil))
values.changed({ $0!.someProp }) /* Fatal error: Unexpectedly found nil while unwrapping an Optional value */
values.changed({ $0?.someProp }) /* error: cannot convert value of type '(TestClass?) -> PropClass?' to expected argument type '(TestClass?) -> _' */
出现第二个错误,因为它不能在两个Optional上使用===。
答案 0 :(得分:0)
刚刚花了几个小时寻找类似问题的解决方案,我想我终于找到了。要检查泛型类型的嵌套值是否为 nil
,您可以使用:
if (newValue as AnyObject) is NSNull {
//value is nil
}