Answers:
您可以使用“模式匹配”运算符~=
:
if 200 ... 299 ~= statusCode {
print("success")
}
或带有表达式模式的切换语句(内部使用模式匹配运算符):
switch statusCode {
case 200 ... 299:
print("success")
default:
print("failure")
}
请注意,它..<
表示忽略上限值的范围,因此您可能需要
200 ... 299
或200 ..< 300
。
附加信息:在优化打开的情况下,在Xcode 6.3中编译以上代码时,进行测试
if 200 ... 299 ~= statusCode
实际上根本不产生任何函数调用,只有三个汇编指令:
addq $-200, %rdi
cmpq $99, %rdi
ja LBB0_1
这是与生成的完全相同的汇编代码
if statusCode >= 200 && statusCode <= 299
您可以使用
xcrun -sdk macosx swiftc -O -emit-assembly main.swift
从Swift 2开始,可以写成
if case 200 ... 299 = statusCode {
print("success")
}
对if语句使用新引入的模式匹配。另请参见“ if”中的Swift 2-模式匹配。
func ~= (Range<A>, A) -> Bool
调用了一个库函数。我假设该函数与O(1)一起使用。
xcrun -sdk macosx swift -emit-assembly main.swift
并检查了汇编代码。然后,我通常xcrun swift-demangle ...
将调用函数的名称拆散。-不幸的是,Xcode尚无法为Swift文件创建汇编代码,也许它将在更高版本中运行。
这个版本似乎比模式匹配更具可读性:
if (200 ... 299).contains(statusCode) {
print("Success")
}
这是一个旧线程,但在我看来,我们对此考虑过度。在我看来,最好的答案就是
if statusCode >= 200 && statusCode <= 299
没有啦
if 200 > statusCode > 299
我知道的其他形式,以及其他建议的解决方案都在进行函数调用,这些函数较难阅读,执行起来可能较慢。模式匹配方法是一个有用的技巧,但似乎不适合解决此问题。
我个人认为模式匹配运算符很丑陋,希望编译器支持if x in 1...100
语法。这比直接直观得多而且易于阅读if 1...100 ~= x
if 200 ... 299 ~= statusCode
,没有函数调用:)
if 200 ... 299 ~= statusCode
给出了相同的组件代码if statusCode >= 200 && statusCode <= 299
我首选范围。载有()操作过,直到发现它的实现是低效- https://oleb.net/blog/2015/09/swift-ranges-and-intervals/
我们可以使用范围表示条件x <0:(Int.min .. <0).contains(x)完全等效。但是,它要慢得多。默认情况下,contains(_ :)遍历整个集合,在最坏的情况下执行循环九百亿次并不便宜。