大佬教程收集整理的这篇文章主要介绍了在Swift中实现“Either”结构,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
struct Either <T1,T2> { let first: T1? let second: T2? init(first: T1?,second: T2?) { self.first = first self.second = second } func either() -> Bool { return (self.first != nil) || (self.second != nil) } func which() -> Any? { if self.first != nil { return self.first } else if self.second != nil { return self.second } return nil } } var s1: String? = nil var s2: Int? = nil let b1 = Either(first: s1,second: s2) b1.either() // false b1.which() // {nil} s1 = "Hello" let b2 = Either(first: s1,second: s2) b2.either() // true b2.which() // {Some Hello} s1 = nil s2 = 7 let b3 = Either(first: s1,second: s2) b3.either() // true b3.which() // {Some 7} // all as expected,however let b4 = Either(first: nil,second: nil) b4.either() // true !!! <<<<<<<<<<<<<<<<<< b4.which() // {nil}
我认为它与“可选的选项”有关,但我不确定它是否符合预期.
问题在于类型 – 从文字创建Either时:
let b4 = Either(first: nil,second: nil)
然后编译器无法推断出nil参数的类型.如果检查调试器,您将看到推断类型是一个名为_Nil的类型.
(lldb) p b4 (SwiftConsole.Either<_Nil,_Nil>) $R1 = { first = Some second = Some }
let x: _Nil = nil //this is not an optional
初始化器正在对它进行选择,因此将值设为Optional.some(nil),因为它是.some(…)值,将它与nil进行比较将为false.
我没有看到任何简单的通用解决方法,但在这种情况下,它将有助于明确指定泛型类型:
let b4 = Either<String,Int>(first: nil,second: nil)
我建议你报告一个错误,因为这只是愚蠢的.编译器应该反而触发错误,而不是推断一些导致未定义行为的特殊类型.
类型为Any会出现同样的问题,因为它也可以接受nil而不是可选的.
let x: Any = nil //this is not an optional Either<Any,Any>(first: nil,second: nil).which() //true !!!
以上是大佬教程为你收集整理的在Swift中实现“Either”结构全部内容,希望文章能够帮你解决在Swift中实现“Either”结构所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。