对于没有默认情况的Double类型,swift开关可以是穷举吗?
var minY = 1.0 switch minY { case -(Double.infinity)..<0.9: yAxisMinimum = 0.0 case (0.9..<0.99): yAxisMinimum = 0.9 case (0.99..<0.999): yAxisMinimum = 0.99 case (0.999..<0.9999): yAxisMinimum = 0.999 case (0.9999...Double.infinity): yAxisMinimum = 0.9999 }
但是这个带有(无用的)默认情况的开关可以工作:
var minY = 1.0 switch minY { case -(Double.infinity)..<0.9: yAxisMinimum = 0.0 case (0.9..<0.99): yAxisMinimum = 0.9 case (0.99..<0.999): yAxisMinimum = 0.99 case (0.999..<0.9999): yAxisMinimum = 0.999 case (0.9999...Double.infinity): yAxisMinimum = 0.9999 default: yAxisMinimum = 0.0 }
我尽量避免使用我的开关的默认情况,但不知道是否可以使用Double.
没有
because only enum types can be exhaustively checked.
但在这种情况下,问题甚至更深.即使整数可以被彻底检查,你仍然无法在没有where子句的情况下彻底检查Double.其中一个选项是.nan(“不是数字”),你没有考虑.所以你可能会认为只是添加这种情况:
case .nan: yAxisMinimum = .nan
这不仅不会使它变得详尽,它甚至不会按照你期望的方式工作.
var minY = Double.nan switch minY { case -(Double.infinity)..<0.9: yAxisMinimum = 0.0 // ... case .nan: yAxisMinimum = .nan default: yAxisMinimum = 0 } yAxisMinimum // 0
为什么?因为这:
var minY = Double.nan minY == .nan // false
NaN与一切都不相同,包括NaN.所以没有办法直接将它包含在switch语句中.你必须使用where子句:
case _ where minY.isNaN: yAxisMinimum = .nan
这肯定超出了编译器的验证能力.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。