我想构建一个像黑板一样的结构,其中值的类型被包装,以便BlackboardValue
可以传递而不受实际持有类型的限制。
其次,我需要检查两个BlackboardValue
是否具有相同类型的值。使用BlackboardValue<T>
似乎不起作用,因为BlackboardValue<String>
不能与BlackboardValue<Double>
和其他问题一起存储。 BlackboardValue
应该是单一类型。
我认为问题可以归结为我似乎无法检查两个包装器是否具有相同的类型:
import Foundation
class Wrapper {
var value: Any?
init(v: Any) {
self.value = v
}
}
func wrappersHoldTheSameValueType(w1: Wrapper, w2: Wrapper) -> Bool {
return false
}
var w = Wrapper(v: "Hans")
var d = w.value as String
我已经找到了一种方法。试试这种方式。
func wrappersHoldTheSameValueType(w1: Wrapper, w2: Wrapper) -> Bool {
let typeidof = { (a: Any) in
unsafeBitCast(reflect(a).valueType, uintptr_t.self)
}
switch ((w1.value, w2.value)) {
case let (.Some(a), .Some(b)):
return typeidof(a) == typeidof(b)
case (nil, nil):
return true
default:
return false
}
}
有点尴尬,但至少目前似乎有效。
wrappersHoldTheSameValueType(Wrapper(v:1), Wrapper(v:2)) // ==> true
wrappersHoldTheSameValueType(Wrapper(v:"a"), Wrapper(v:"b")) // ==> true
wrappersHoldTheSameValueType(Wrapper(v:["a"]), Wrapper(v:["b"])) // ==> true
wrappersHoldTheSameValueType(Wrapper(v:UIView()), Wrapper(v:1)) // ==> false
wrappersHoldTheSameValueType(Wrapper(v:[1]), Wrapper(v:["a"])) // ==> false