前言
我在看喵神的書的時候,發現書中有個練習(如下圖),我覺得挺有意思,就把其中的“||”操作符實現了一下,跟大家分享一下。
使用Swift實現“||”操作符,我發現有三種方式,各自特點如下:
“||”操作符,其實就是比較其左右兩側的值。所以我先定義一個常量vLeft代表左側的值。因為右側的值比較特殊,所以我定義了一個返回值為Bool值的函數getRightRes來獲取右側的值,代碼如下:
let vLeft = 31 > 12 // 代表操作符左側的值 // 代表操作符右側的值func getRightRes() -> Bool { print("getting the right value...") return 2 < 10}
第一種:
這是最普通,也是最容易想到的方式。函數有兩個Bool類型的參數,value1為true是直接返回true,value1為false時,再判斷value2的值。代碼如下:
func or(_ value1: Bool, _ value2: Bool) -> Bool { if value1 { return true } if value2 { return true } return false}
然后使用定義好的值調用一下:
let res = or(vLeft, getRightRes())print("or: /(res)/n")
打印結果為:
getting the right value...
or: true
大家有沒有發現一個問題,即使我左側的值vLeft為true了,獲取右側值的函數getRightRes依然被執行了。試想如果右側函數是個比較消耗性能或費時的操作,在已經確定結果為true的情況下,再去執行右側函數,則非常沒有必要了!
那有沒有辦法解決這個問題呢?當然有,請看第二種方式。
第二種:
這種方式使用了閉包的概念。函數的第一個參數還是Bool類型的值,但第二個參數改為了一個返回值為Bool類型的閉包。(我們會把getRightRes函數放在閉包中執行)代碼如下:
func or(_ value1: Bool, _ value2: () -> Bool) -> Bool { if value1 { return true } return value2()}
這段代碼的意思就是,如果value1為true直接返回true,如果value1為false,則返回value2閉包的返回值。
這個函數的調用如下:
let res = or(vLeft) { () -> Bool in return getRightRes()}print("or: /(res)/n")
執行結果如下:
or: true
大家發現沒有,在vLeft為true的情況下,并沒有再去調用getRightRes函數。這就解決了第一種方式中存在的問題。
現在我們把vLeft的值改為let vLeft = 3 > 12,再次運行代碼,會發現結果如下:
getting the right value...
or: true
這就說明,在左側值value1為false的情況時,會執行value2的閉包,閉包中的函數getRightRes會被執行,并返回結果。
這個函數的調用方式還可以簡寫為如下方式:
let res = or(vLeft) { getRightRes()}
第三種:
這種方式只是在第二種方式的寫法上進行了優化,即在閉包參數的前面加了@autoclosure關鍵字,作用就是在調用這個函數的時候,寫法非常優雅,你甚至都感受不到閉包的存在!代碼如下:
func or(_ value1: Bool, _ value2: @autoclosure() -> Bool) -> Bool { if value1 { return true } return value2()}
調用代碼:
let res = or(vLeft, getRightRes())print("or: /(res)/n")
運行結果是跟第二種方式是一樣的,但寫法上比第二種簡潔了很多。跟第一種普通方式的調用代碼竟然是一模一樣的。
以上就是我總結的使用Swift實現“或”操作符的三種方式了,希望對大家有幫助。
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對VEVB武林網的支持。
新聞熱點
疑難解答