C語(yǔ)言詳細(xì)講解循環(huán)語(yǔ)句的妙用
一、循環(huán)語(yǔ)句分析
循環(huán)語(yǔ)句的基本工作方式
- 通過(guò)條件表達(dá)式判定是否執(zhí)行循環(huán)體
- 條件表達(dá)式遵循 if 語(yǔ)句表達(dá)式的原則
do,while,for的區(qū)別
- do 語(yǔ)句先執(zhí)行后判斷,循環(huán)體至少執(zhí)行一次
- while 語(yǔ)句先判斷后執(zhí)行,循環(huán)體可能不執(zhí)行
- for 語(yǔ)句先判斷后執(zhí)行,相比 while 更簡(jiǎn)潔
二、do ... while 語(yǔ)句的循環(huán)方式


三、while 語(yǔ)句的循環(huán)方式


四、for 語(yǔ)句的循環(huán)方式


下面看一段三種循環(huán)語(yǔ)句使用對(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)體。
如果采用下面這種寫(xiě)法:
#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;
}可以看到程序并沒(méi)有輸出 free(p),也就是說(shuō)申請(qǐng)的內(nèi)存并沒(méi)有得到釋放,造成內(nèi)存泄漏。

所以說(shuō)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語(yǔ)言詳細(xì)講解循環(huán)語(yǔ)句的妙用的文章就介紹到這了,更多相關(guān)C語(yǔ)言循環(huán)語(yǔ)句內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C語(yǔ)言對(duì)冒泡排序進(jìn)行升級(jí)介紹
大家好,本篇文章主要講的是C語(yǔ)言對(duì)冒泡排序進(jìn)行升級(jí)介紹,感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話記得收藏一下2022-01-01
C++ OpenCV實(shí)戰(zhàn)之文檔照片轉(zhuǎn)換成掃描文件
這篇文章主要為大家介紹一個(gè)C++?OpenCV的實(shí)戰(zhàn)——文檔照片轉(zhuǎn)換成掃描文件,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2022-09-09
C++哈希應(yīng)用之位圖,哈希切分與布隆過(guò)濾器詳解
這篇文章主要為大家詳細(xì)介紹了C++哈希應(yīng)用中的位圖、哈希切分與布隆過(guò)濾器,文中的示例代碼講解詳細(xì),具有一定的學(xué)習(xí)價(jià)值,需要的可以參考一下2023-04-04
C++?TCP網(wǎng)絡(luò)編程詳細(xì)講解
TCP/IP是一種面向連接的、可靠的、基于字節(jié)流的傳輸層通信協(xié)議,它會(huì)保證數(shù)據(jù)不丟包、不亂序。TCP全名是Transmission?Control?Protocol,它是位于網(wǎng)絡(luò)OSI模型中的第四層2022-09-09
C++類(lèi)與對(duì)象深入之運(yùn)算符重載與const及初始化列表詳解
運(yùn)算符是程序中最最常見(jiàn)的操作,例如對(duì)于內(nèi)置類(lèi)型的賦值我們直接使用=賦值即可,因?yàn)檫@些編譯器已經(jīng)幫我們做好了,但是對(duì)象的賦值呢?能直接賦值嗎2022-06-06
C語(yǔ)言深入探究水仙花數(shù)與變種水仙花數(shù)代碼
求水仙花數(shù)和變種水仙花數(shù)是非常適合初學(xué)者學(xué)習(xí)的代碼,其中包含的循環(huán)和邏輯方式等知識(shí)點(diǎn)。這既能起到對(duì)以往知識(shí)的復(fù)習(xí),也可以學(xué)習(xí)到一種不同的邏輯思考方式2022-05-05
C++實(shí)現(xiàn)冒泡排序(BubbleSort)
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)冒泡排序,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-04-04

