- 相關推薦
C語言的關鍵字和控制語句有哪些
C語言的關鍵字共有32個,根據(jù)關鍵字的作用,可分其為數(shù)據(jù)類型關鍵字、控制語句關鍵字、存儲類型關鍵字和其它關鍵字四類。下面是相關的知識,歡迎閱讀。
一、C語言中的關鍵字:
1 數(shù)據(jù)類型關鍵字(12個):
(1) char :聲明字符型變量或函數(shù)
(2) double :聲明雙精度變量或函數(shù)
(3) enum :聲明枚舉類型
(4) float:聲明浮點型變量或函數(shù)
(5) int: 聲明整型變量或函數(shù)
(6) long :聲明長整型變量或函數(shù)
(7) short :聲明短整型變量或函數(shù)
(8) signed:聲明有符號類型變量或函數(shù)
(9) struct:聲明結構體變量或函數(shù)
(10) union:聲明共用體(聯(lián)合)數(shù)據(jù)類型
(11) unsigned:聲明無符號類型變量或函數(shù)
(12) void :聲明函數(shù)無返回值或無參數(shù),聲明無類型指針(基本上就這三個作用)
2控制語句關鍵字(12個):
A循環(huán)語句
(1) for:一種循環(huán)語句(可意會不可言傳)
(2) do :循環(huán)語句的循環(huán)體
(3) while :循環(huán)語句的循環(huán)條件
(4) break:跳出當前循環(huán)
(5) continue:結束當前循環(huán),開始下一輪循環(huán)
B條件語句
(1)if: 條件語句
(2)else :條件語句否定分支(與 if 連用)
(3)goto:無條件跳轉語句
C開關語句
(1)switch :用于開關語句
(2)case:開關語句分支
(3)default:開關語句中的“其他”分支
D返回語句
return :子程序返回語句(可以帶參數(shù),也看不帶參數(shù))
3 存儲類型關鍵字(4個)
(1)auto :聲明自動變量 一般不使用
(2)extern:聲明變量是在其他文件正聲明(也可以看做是引用變量)
(3)register:聲明積存器變量
(4)static :聲明靜態(tài)變量
4 其它關鍵字(4個):
(1)const :聲明只讀變量
(2)sizeof:計算數(shù)據(jù)類型長度
(3)typedef:用以給數(shù)據(jù)類型取別名(當然還有其他作用)
(4)volatile:說明變量在程序執(zhí)行中可被隱含地改變
二、C語言中的9中控制語句
goto語句:無條件轉向;
if語句:判斷語句;
while循環(huán)語句;
do-while語句:先執(zhí)行循環(huán)體,然后判斷循環(huán)條件是否成立. 之后繼續(xù)循環(huán);
for語句:循環(huán),可替代while語句; 只是用法不同;
break語句跳出本層的循環(huán);(只跳出包含此語句的循環(huán))
continue語句:繼續(xù)(一般放到循環(huán)語句里,不在執(zhí)行它下面的語句,直接跳到判斷語句例:for語句,就直接跳到第二個分號處,while語句,就直接跳到while()的括號里;
switch語句:多相選擇;
return語句:返回;
C語言基本算法
1.交換(兩量交換借助第三者)
例1、任意讀入兩個整數(shù),將二者的值交換后輸出。
main()
{int a,b,t;
scanf("%d%d",&a,&b);
printf("%d,%d ",a,b);
t=a; a=b; b=t;
printf("%d,%d ",a,b);}
【解析】程序中加粗部分為算法的核心,如同交換兩個杯子里的飲料,必須借助第三個空杯子。
假設輸入的值分別為3、7,則第一行輸出為3,7;第二行輸出為7,3。
其中t為中間變量,起到“空杯子”的作用。
注意:三句賦值語句賦值號左右的各量之間的關系!
【應用】
例2、任意讀入三個整數(shù),然后按從小到大的順序輸出。
main()
{int a,b,c,t;
scanf("%d%d%d",&a,&b,&c);
if(a>b){ t=a; a=b; b=t; }
if(a>c){ t=a; a=c; c=t; }
if(b>c) { t=b; b=c; c=t; }
printf("%d,%d,%d ",a,b,c);}
2.累加
累加算法的要領是形如“s=s+A”的累加式,此式必須出現(xiàn)在循環(huán)中才能被反復執(zhí)行,從而實現(xiàn)累加功能!癆”通常是有規(guī)律變化的表達式,s在進入循環(huán)前必須獲得合適的初值,通常為0。
例1、求1+2+3+……+100的和。
main()
{int i,s;
s=0; i=1;
while(i<=100)
{s=s+i;
i=i+1;
}
printf("1+2+3+...+100=%d ",s);}
【解析】程序中加粗部分為累加式的典型形式,賦值號左右都出現(xiàn)的變量稱為累加器,其中“i = i + 1”為特殊的累加式,每次累加的值為1,這樣的累加器又稱為計數(shù)器。
3.累乘
累乘算法的要領是形如“s=s*A”的累乘式,此式必須出現(xiàn)在循環(huán)中才能被反復執(zhí)行,從而實現(xiàn)累乘功能!癆”通常是有規(guī)律變化的表達式,s在進入循環(huán)前必須獲得合適的初值,通常為1。
例1、求10!
[分析]10!=1×2×3×……×10
main()
{int i; long c;
c=1; i=1;
while(i<=10)
{c=c*i;
i=i+1;
}
printf("1*2*3*...*10=%ld ",c);}
C語言定義
宏定義的一般形式為:
#define 宏名 字符串
#表示這是一條預處理命令,所有的預處理命令都以#開頭。define是預處理命令。宏名是標識符的一種,命名規(guī)則和標識符相同。字符串可以是常數(shù)、表達式等。
這里所說的字符串是一般意義上的字符序列,不要和C語言中的字符串等同,它不需要雙引號。
程序中反復使用的表達式就可以使用宏定義,例如:
#define M (n*n+3*n)
它的作用是指定標識符M來代替表達式(y*y+3*y)。在編寫源程序時,所有的(y*y+3*y)都可由M代替,而對源程序編譯時,將先由預處理程序進行宏代換,即用(y*y+3*y)表達式去替換所有的宏名M,然后再進行編譯。
將上面的例子補充完整:
#include#define M (n*n+3*n)int main(){ int sum, n; printf("Input a number: "); scanf("%d", &n); sum = 3*M+4*M+5*M; printf("sum=%d ", n); return 0;}
運行結果:
Input a number: 10↙
sum=1560
上面的程序中首先進行宏定義,定義M來替代表達式(n*n+3*n),在sum=3*M+4*M+5*M中作了宏調用。在預處理時經(jīng)宏展開后該語句變?yōu)椋?/p>
sum=3*(n*n+3*n)+4*(n*n+3*n)+5*(n*n+3*n);
需要注意的是,在宏定義中表達式(n*n+3*n)兩邊的括號不能少,否則會發(fā)生錯誤。如當作以下定義后:
#difine M n*n+3*n
在宏展開時將得到下述語句:
s=3*n*n+3*n+4*n*n+3*n+5*n*n+3*n;
這相當于:
3n2+3n+4n2+3n+5n2+3n
這顯然是不正確的。所以進行宏定義時要注意,應該保證在宏代換之后不發(fā)生錯誤。
對宏定義的幾點說明
1) 宏定義是用宏名來表示一個字符串,在宏展開時又以該字符串取代宏名,這只是一種簡單的替換。字符串中可以含任何字符,可以是常數(shù),也可以是表達式,預處理程序對它不作任何檢查,如有錯誤,只能在編譯已被宏展開后的源程序時發(fā)現(xiàn)。
2) 宏定義不是說明或語句,在行末不必加分號,如加上分號則連分號也一起替換。
3) 宏定義必須寫在函數(shù)之外,其作用域為宏定義命令起到源程序結束。如要終止其作用域可使用#undef命令。例如:
#define PI 3.14159int main(){ // Code return 0;}#undef PIvoid func(){ // Code}
表示PI只在main函數(shù)中有效,在func中無效。
4) 宏名在源程序中若用引號括起來,則預處理程序不對其作宏代換,例如:
#include#define OK 100int main(){ printf("OK "); return 0;}
運行結果:
OK
該例中定義宏名OK表示100,但在 printf 語句中 OK 被引號括起來,因此不作宏代換,而作為字符串處理。
5) 宏定義允許嵌套,在宏定義的字符串中可以使用已經(jīng)定義的宏名,在宏展開時由預處理程序層層代換。例如:
#define PI 3.1415926
#define S PI*y*y /* PI是已定義的宏名*/
對語句:
printf("%f", S);
在宏代換后變?yōu)椋?/p>
printf("%f", 3.1415926*y*y);
6) 習慣上宏名用大寫字母表示,以便于與變量區(qū)別。但也允許用小寫字母。
7) 可用宏定義表示數(shù)據(jù)類型,使書寫方便。例如:
#define UINT unsigned int
在程序中可用UINT作變量說明:
UINT a, b;
應注意用宏定義表示數(shù)據(jù)類型和用typedef定義數(shù)據(jù)說明符的區(qū)別。宏定義只是簡單的字符串代換,是在預處理完成的,而typedef是在編譯時處理的,它不是作簡單的代換,而是對類型說明符重新命名。被命名的標識符具有類型定義說明的功能。
請看下面的例子:
#define PIN1 int *
typedef (int *) PIN2;
從形式上看這兩者相似, 但在實際使用中卻不相同。
下面用PIN1,PIN2說明變量時就可以看出它們的區(qū)別:
PIN1 a,b;
在宏代換后變成:
int *a,b;
表示a是指向整型的指針變量,而b是整型變量。然而:
PIN2 a,b;
表示a、b都是指向整型的指針變量。因為PIN2是一個類型說明符。由這個例子可見,宏定義雖然也可表示數(shù)據(jù)類型, 但畢竟是作字符代換。在使用時要分外小心,以避出錯。
C語言優(yōu)缺點
1. 簡潔緊湊、靈活方便
C語言一共只有32個關鍵字,9種控制語句,程序書寫形式自由,主要用小寫字母表示。它把高級語言的基本結構和語句與低級語言的實用性結合起來。 C 語言可以像匯編語言一樣對位、字節(jié)和地址進行操作,而這三者是計算機最基本的工作單元。
2. 運算符豐富
C語言的運算符包含的范圍很廣泛,共有34種運算符。C語言把括號、賦值、強制類型轉換等都作為運算符處理。從而使C語言的運算類型極其豐富,表達式類型多樣化。靈活使用各種運算符可以實現(xiàn)在其它高級語言中難以實現(xiàn)的運算。
3. 數(shù)據(jù)結構豐富
C語言的數(shù)據(jù)類型有:整型、實型、字符型、數(shù)組類型、指針類型、結構體類型、共用體類型等。能用來實現(xiàn)各種復雜的數(shù)據(jù)結構的運算。并引入了指針概念,使程序效率更高。另外C語言具有強大的圖形功能,支持多種顯示器和驅動器。且計算功能、邏輯判斷功能強大。
4. C是結構式語言
結構式語言的顯著特點是代碼及數(shù)據(jù)的分隔化,即程序的各個部分除了必要的信息交流外彼此獨立。這種結構化方式可使程序層次清晰,便于使用、維護以及調試。C語言是以函數(shù)形式提供給用戶的,這些函數(shù)可方便的調用,并具有多種循環(huán)、條件語句控制程序流向,從而使程序完全結構化。
5.C語法限制
C語法限制不太嚴格,程序設計自由度大 雖然C語言也是強類型語言,但它的語法比較靈活,允許程序編寫者有較大的自由度
6. C語言允許直接訪問物理地址,可以直接對硬件進行操作
由于C語言允許直接訪問物理地址,可以直接對硬件進行
【C語言的關鍵字和控制語句有哪些】相關文章:
C語言控制語句考點03-28
C語言的缺點有哪些12-04
C語言關鍵字RESTRICT介紹10-25
C語言關鍵字及其解釋03-10
C語言的特點及版本有哪些03-26
C語言assert的用法有哪些04-02
C語言中volatile關鍵字分析03-30
C語言必須知道的關鍵字12-03