練習11:While循環(huán)和布爾表達式
譯者:飛龍
你已經(jīng)初步了解C是如何處理循環(huán)的褪秀,但是你可能不是很清楚布爾表達式i < argc
是什么乙埃。在學習while
循環(huán)之前,讓我先來對布爾表達式做一些解釋辙喂。
在C語言中,實際上沒有真正的“布爾”類型竹勉,而是用一個整數(shù)來代替娄琉,0代表false
次乓,其它值代表true
。上一個練習中表達式i < argc
實際上值為1或者0票腰,并不像Python是顯式的Ture
或者False
女气。這是C語言更接近計算機工作方式的另一個例子炼鞠,因為計算機只把值當成數(shù)字霎肯。
現(xiàn)在用while
循環(huán)來實現(xiàn)和上一個練習相同的函數(shù)懂缕。這會讓你兩種循環(huán)搪柑,看看兩種循環(huán)是什么關系吮蛹。
#include <stdio.h>
int main(int argc, char *argv[])
{
// go through each string in argv
int i = 0;
while(i < argc) {
printf("arg %d: %s\n", i, argv[i]);
i++;
}
// let's make our own array of strings
char *states[] = {
"California", "Oregon",
"Washington", "Texas"
};
int num_states = 4;
i = 0; // watch for this
while(i < num_states) {
printf("state %d: %s\n", i, states[i]);
i++;
}
return 0;
}
你可以看到while
循環(huán)的語法更加簡單:
while(TEST) {
CODE;
}
只要TEST
為true
(非0),就會一直運行CODE
中的代碼倚喂。這意味著如果要達到和for
循環(huán)同樣的效果,我們需要自己寫初始化語句,以及自己來增加i
端圈。
你會看到什么
輸出基本相同焦读,所以我做了一點修改,你可以看到它運行的另一種方式舱权。
$ make ex11
cc -Wall -g ex11.c -o ex11
$ ./ex11
arg 0: ./ex11
state 0: California
state 1: Oregon
state 2: Washington
state 3: Texas
$
$ ./ex11 test it
arg 0: ./ex11
arg 1: test
arg 2: it
state 0: California
state 1: Oregon
state 2: Washington
state 3: Texas
$
如何使它崩潰
在你自己的代碼中矗晃,應有限選擇for
循環(huán)而不是while
循環(huán),因為for
循環(huán)不容易崩潰宴倍。下面是幾點普遍的原因:
- 忘記初始化
int i
张症,使循環(huán)發(fā)生錯誤。 - 忘記初始化第二個循環(huán)的
i
鸵贬,于是i
還保留著第一個循環(huán)結束時的值俗他。你的第二個循環(huán)可能執(zhí)行也可能不會執(zhí)行。 - 忘記在最后執(zhí)行
i++
自增阔逼,你會得到一個“死循環(huán)”兆衅,它是在你開始編程的第一個或前兩個十年中,最可怕的問題之一嗜浮。
附加題
- 讓這些循環(huán)倒序執(zhí)行羡亩,通過使用
i--
從argc
開始遞減直到0。你可能需要做一些算數(shù)操作讓數(shù)組的下標正常工作危融。 - 使用
while
循環(huán)將argv
中的值復制到states
畏铆。 - 讓這個復制循環(huán)不會執(zhí)行失敗,即使
argv
之中有很多元素也不會全部放進states
专挪。 - 研究你是否真正復制了這些字符串及志。答案可能會讓你感到意外和困惑。