C語言詳細(xì)講解循環(huán)語句的妙用
一、循環(huán)語句分析
循環(huán)語句的基本工作方式
- 通過條件表達(dá)式判定是否執(zhí)行循環(huán)體
- 條件表達(dá)式遵循 if 語句表達(dá)式的原則
do,while,for的區(qū)別
- do 語句先執(zhí)行后判斷,循環(huán)體至少執(zhí)行一次
- while 語句先判斷后執(zhí)行,循環(huán)體可能不執(zhí)行
- for 語句先判斷后執(zhí)行,相比 while 更簡(jiǎn)潔
二、do ... while 語句的循環(huán)方式
三、while 語句的循環(huán)方式
四、for 語句的循環(huán)方式
下面看一段三種循環(huán)語句使用對(duì)比的代碼:
#include <stdio.h> int f1(int n) { int ret = 0; if( n > 0 ) { do { ret += n; n--; } while( n > 0 ); } return ret; } int f2(int n) { int ret = 0; while( n > 0 ) { ret += n; n--; } return ret; } int f3(int n) { int ret = 0; int i = 0; for(i=1; i<=n; i++) { ret += i; } return ret; } int main() { printf("%d\n", f1(100)); printf("%d\n", f2(100)); printf("%d\n", f3(100)); return 0; }
下面為輸出結(jié)果:
五、break和 continue 的區(qū)別
- break 表示終止循環(huán)的執(zhí)行
- continue 表示終止本次循環(huán),進(jìn)入下次循環(huán)執(zhí)行
下面看一段 continue 和 break 的區(qū)別代碼:
#include <stdio.h> void f1(int n) { int i = 0; for(i=1; i<=n; i++) { if( (i % 2) == 0 ) { break; } printf("%d ", i); } printf("\n"); } void f2(int n) { int i = 0; for(i=1; i<=n; i++) { if( (i % 2) == 0 ) { continue; } printf("%d ", i); } printf("\n"); } int main() { f1(10); f2(10); return 0; }
下面為輸出結(jié)果:
六、do 和 break 的妙用
#include <stdio.h> #include <malloc.h> int func(int n) { int i = 0; int ret = 0; int* p = (int*)malloc(sizeof(int) * n); do { if( NULL == p ) break; if( n < 5 ) break; if( n > 100) break; for(i=0; i<n; i++) { p[i] = i; printf("%d\n", p[i]); } ret = 1; }while( 0 ); printf("free(p)\n"); free(p); return ret; } int main() { if( func(10) ) { printf("OK\n"); } else { printf("ERROR\n"); } return 0; }
下面為輸出結(jié)果:
注意 do{ } while(0)是只執(zhí)行一次循環(huán)體。
如果采用下面這種寫法:
#include <stdio.h> #include <malloc.h> int func(int n) { int i = 0; int ret = 0; int* p = (int*)malloc(sizeof(int) * n); if( NULL == p ) return ret; if( n < 5 ) return ret; if( n > 100) return ret; for(i=0; i<n; i++) { p[i] = i; printf("%d\n", p[i]); } ret = 1; printf("free(p)\n"); free(p); return ret; } int main() { if( func(4) ) { printf("OK\n"); } else { printf("ERROR\n"); } return 0; }
可以看到程序并沒有輸出 free(p),也就是說申請(qǐng)的內(nèi)存并沒有得到釋放,造成內(nèi)存泄漏。
所以說do 和 break 一起妙用,可以暴力跳出當(dāng)前循環(huán),避免內(nèi)存泄漏。
七、小結(jié)
- for 循環(huán)先進(jìn)行判斷再進(jìn)入循環(huán)體
- for 循環(huán)適合于循環(huán)次數(shù)固定的場(chǎng)合
- while 循環(huán)先進(jìn)行判斷再進(jìn)入循環(huán)體執(zhí)行
- while 循環(huán)適合于循環(huán)次數(shù)不定的場(chǎng)合
- do ... while 循環(huán)先執(zhí)行循環(huán)體再進(jìn)行條件判斷
- do ... while 循環(huán)至少執(zhí)行一次循環(huán)體
到此這篇關(guān)于C語言詳細(xì)講解循環(huán)語句的妙用的文章就介紹到這了,更多相關(guān)C語言循環(huán)語句內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C++ OpenCV實(shí)戰(zhàn)之文檔照片轉(zhuǎn)換成掃描文件
這篇文章主要為大家介紹一個(gè)C++?OpenCV的實(shí)戰(zhàn)——文檔照片轉(zhuǎn)換成掃描文件,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2022-09-09C++?TCP網(wǎng)絡(luò)編程詳細(xì)講解
TCP/IP是一種面向連接的、可靠的、基于字節(jié)流的傳輸層通信協(xié)議,它會(huì)保證數(shù)據(jù)不丟包、不亂序。TCP全名是Transmission?Control?Protocol,它是位于網(wǎng)絡(luò)OSI模型中的第四層2022-09-09C++類與對(duì)象深入之運(yùn)算符重載與const及初始化列表詳解
運(yùn)算符是程序中最最常見的操作,例如對(duì)于內(nèi)置類型的賦值我們直接使用=賦值即可,因?yàn)檫@些編譯器已經(jīng)幫我們做好了,但是對(duì)象的賦值呢?能直接賦值嗎2022-06-06C語言深入探究水仙花數(shù)與變種水仙花數(shù)代碼
求水仙花數(shù)和變種水仙花數(shù)是非常適合初學(xué)者學(xué)習(xí)的代碼,其中包含的循環(huán)和邏輯方式等知識(shí)點(diǎn)。這既能起到對(duì)以往知識(shí)的復(fù)習(xí),也可以學(xué)習(xí)到一種不同的邏輯思考方式2022-05-05C++實(shí)現(xiàn)冒泡排序(BubbleSort)
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)冒泡排序,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-04-04