記得剛學習寫程式時, 寫到關於 condition 的表示式時, 偶而會碰到這樣的窘境.
如果第一個 condition 換成 amount = 1 時, 結果又會是如何呢?
答案是 => 永遠只會跑到 // do something 1 的區段. WHY???
很多老師都會用心良苦的跟學生說 “=” 和 “==” 是不同的, 寫 assignment 的時候用的是 “=”, 寫 conditon 的時候, 用的是 “==”.很多學生也就這麼記下來了, 但永遠不了解為什麼 condition 裡頭會是這個樣子, 一樣都是寫錯, =0 和 =1 的結果卻不同.
那何時 condition 會成立? 也就是 condition 內容為真, 那什麼叫做內容為真? 看一下在 Objective-C 之中 BOOL、YES 和 NO 的定義:
雖然 YES 為 1, 但其實 condition 的成立條件為 !NO (非 0), 也就是說不管上述第一個 condition 中的 amount assign 的數字是多少, 只要不是 0, 這個 condition 通通會成立.
講這麼多, 其實只要能確實了解 “=” 和 “==” 之間的差異, 就沒什麼大問題.
但如果一時不察用錯了怎麼辦? 那剛剛上面一大篇枯燥無味的基礎知識, 就可以幫助你快速的找出這個僅有一字元之差的小 bug. 而不會花了一個晚上想破頭, 最後還不見得能發現原來只是把 “==” 寫成了 “=”.
if (amount = 0) {乍看之下似乎沒啥問題, 但實際上問題可大了!! 因為第一個 condition 寫成了 assignment. 導致整個 if-else 的判斷式, 永遠只會跑到 // do something 3 的區段.
// do something 1
} else if (amont > 0) {
// do something 2
} else {
// do something 3
}
如果第一個 condition 換成 amount = 1 時, 結果又會是如何呢?
答案是 => 永遠只會跑到 // do something 1 的區段. WHY???
很多老師都會用心良苦的跟學生說 “=” 和 “==” 是不同的, 寫 assignment 的時候用的是 “=”, 寫 conditon 的時候, 用的是 “==”.很多學生也就這麼記下來了, 但永遠不了解為什麼 condition 裡頭會是這個樣子, 一樣都是寫錯, =0 和 =1 的結果卻不同.
那何時 condition 會成立? 也就是 condition 內容為真, 那什麼叫做內容為真? 看一下在 Objective-C 之中 BOOL、YES 和 NO 的定義:
typedef signed char BOOL;這下就很清楚了, 不成立的狀況 (NO) 就是 0, 這也解釋了為何上述例子 amount = 0 會這樣運作.
#define YES (BOOL)1
#define NO (BOOL)0
雖然 YES 為 1, 但其實 condition 的成立條件為 !NO (非 0), 也就是說不管上述第一個 condition 中的 amount assign 的數字是多少, 只要不是 0, 這個 condition 通通會成立.
講這麼多, 其實只要能確實了解 “=” 和 “==” 之間的差異, 就沒什麼大問題.
但如果一時不察用錯了怎麼辦? 那剛剛上面一大篇枯燥無味的基礎知識, 就可以幫助你快速的找出這個僅有一字元之差的小 bug. 而不會花了一個晚上想破頭, 最後還不見得能發現原來只是把 “==” 寫成了 “=”.
留言
請問您是... 爽爽替代役學弟嗎? ="=bbb 如果猜錯還請見諒... XDDD
好啦回到問題點關於 java 的 boolean,
java 中的 boolean 是一種 primitive data type!
這和 C 不一樣! 也就是對 JVM 來說, 天生就認得 boolean. 而 boolean 的值只有 true 或 false. 那一個 boolean 多大的記憶體空間? 1 bit? 1byte? 這得看 JVM 怎麼實作.
也因此 condition 需要的資料形態是 boolean, 自然而然可以避開這個問題.
附帶一提, Objective-C 的官方文件中提到, "A Boolean value, either YES or NO. Note that the type of BOOL is char."
實際上 BOOL 的宣告呢?
=> typedef signed char BOOL;