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 更簡潔
二、do ... while 語句的循環(huán)方式


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


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


下面看一段三種循環(huán)語句使用對比的代碼:
#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),也就是說申請的內(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ù)固定的場合
- while 循環(huán)先進(jìn)行判斷再進(jìn)入循環(huán)體執(zhí)行
- while 循環(huán)適合于循環(huán)次數(shù)不定的場合
- 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)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C++ OpenCV實戰(zhàn)之文檔照片轉(zhuǎn)換成掃描文件
這篇文章主要為大家介紹一個C++?OpenCV的實戰(zhàn)——文檔照片轉(zhuǎn)換成掃描文件,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2022-09-09
C++?TCP網(wǎng)絡(luò)編程詳細(xì)講解
TCP/IP是一種面向連接的、可靠的、基于字節(jié)流的傳輸層通信協(xié)議,它會保證數(shù)據(jù)不丟包、不亂序。TCP全名是Transmission?Control?Protocol,它是位于網(wǎng)絡(luò)OSI模型中的第四層2022-09-09
C語言深入探究水仙花數(shù)與變種水仙花數(shù)代碼
求水仙花數(shù)和變種水仙花數(shù)是非常適合初學(xué)者學(xué)習(xí)的代碼,其中包含的循環(huán)和邏輯方式等知識點。這既能起到對以往知識的復(fù)習(xí),也可以學(xué)習(xí)到一種不同的邏輯思考方式2022-05-05

