基本語法
令牌
C 程式由各種令牌組成,令牌可以是關鍵字、識別符號、常量、字串值,或者是一個符號,例如,下面的 C 陳述句包括五個令牌:
printf("Hello, World! \n");
這五個令牌分別是:
printf
(
"Hello, World! \n"
)
;
分號 ;
在 C 程式中,分號是陳述句結束符,也就是說,每個陳述句必須以分號結束,它表明一個邏輯物體的結束,
注釋
C 語言有兩種注釋方式:
// 單行注釋
以 // 開始的單行注釋,這種注釋可以單獨占一行,
/* 單行注釋 */
/*
多行注釋
多行注釋
多行注釋
*/
/* */ 這種格式的注釋可以單行或多行,
您不能在注釋內嵌套注釋,注釋也不能出現在字串或字符值中,
識別符號
C 識別符號是用來標識變數、函式,或任何其他用戶自定義專案的名稱,一個識別符號以字母 A-Z 或 a-z 或下劃線 _ 開始,后跟零個或多個字母、下劃線和數字(0-9),
C 識別符號內不允許出現標點字符,比如 @、$ 和 %,C 是區分大小寫的編程語言,因此,在 C 中,Manpower 和 manpower 是兩個不同的識別符號,
關鍵字
C 中的保留字,不能作為常量名、變數名或其他識別符號名稱,
在這里查看有哪些關鍵字
C 中的空格
只包含空格的行,被稱為空白行,可能帶有注釋,C 編譯器會完全忽略它,
在 C 中,空格用于描述空白符、制表符、換行符和注釋,空格分隔陳述句的各個部分,讓編譯器能識別陳述句中的某個元素(比如 int)在哪里結束,下一個元素在哪里開始,因此,在下面的陳述句中:
int age;
在這里,int 和 age 之間必須至少有一個空格字符(通常是一個空白符),這樣編譯器才能夠區分它們,另一方面,在下面的陳述句中:
fruit = apples + oranges; // 獲取水果的總數
fruit 和 =,或者 = 和 apples 之間的空格字符不是必需的,但是為了增強可讀性,您可以根據需要適當增加一些空格,
資料型別
在 C 語言中,資料型別指的是用于宣告不同型別的變數或函式的一個廣泛的系統,變數的型別決定了變數存盤占用的空間,以及如何解釋存盤的位模式,
可分為以下幾種:
| 序號 | 型別與描述 |
|---|---|
| 1 | 基本型別: 它們是算術型別,包括兩種型別:整數型別和浮點型別, |
| 2 | 列舉型別: 它們也是算術型別,被用來定義在程式中只能賦予其一定的離散整數值的變數, |
| 3 | void 型別: 型別說明符 void 表明沒有可用的值, |
| 4 | 派生型別: 它們包括:指標型別、陣列型別、結構型別、共用體型別和函式型別, |
陣列型別和結構型別統稱為聚合型別,函式的型別指的是函式回傳值的型別,
整數型別
下表列出了關于標準整數型別的存盤大小和值范圍的細節:
| 型別 | 存盤大小 | 值范圍 |
|---|---|---|
| char | 1 位元組 | -128 到 127 或 0 到 255 |
| unsigned char | 1 位元組 | 0 到 255 |
| signed char | 1 位元組 | -128 到 127 |
| int | 2 或 4 位元組 | -32,768 到 32,767 或 -2,147,483,648 到 2,147,483,647 |
| unsigned int | 2 或 4 位元組 | 0 到 65,535 或 0 到 4,294,967,295 |
| short | 2 位元組 | -32,768 到 32,767 |
| unsigned short | 2 位元組 | 0 到 65,535 |
| long | 4 位元組 | -2,147,483,648 到 2,147,483,647 |
| unsigned long | 4 位元組 | 0 到 4,294,967,295 |
注意,各種型別的存盤大小與系統位數有關,但目前通用的以64位系統為主,
以下列出了32位系統與64位系統的存盤大小的差別(windows 相同):

在Linux中:i686是i386的子集應對高級別CPU的,是32位,x86_64是64位
為了得到某個型別或某個變數在特定平臺上的準確大小,您可以使用 sizeof 運算子,運算式 sizeof(type) 得到物件或型別的存盤位元組大小,下面的實體演示了獲取 int 型別的大小:
#include <stdio.h>
#include <limits.h>
int main()
{
printf("int 存盤大小 : %lu \n", sizeof(int));
return 0;
}
當您在 Linux 上編譯并執行上面的程式時,它會產生下列結果:
int 存盤大小 : 4
%lu 為 32 位無符號整數,詳細說明查看 C 庫函式 - printf(),
浮點型別
下表列出了關于標準浮點型別的存盤大小、值范圍和精度的細節:
| 型別 | 存盤大小 | 值范圍 | 精度 |
|---|---|---|---|
| float | 4 位元組 | 1.2E-38 到 3.4E+38 | 6 位小數 |
| double | 8 位元組 | 2.3E-308 到 1.7E+308 | 15 位小數 |
| long double | 16 位元組 | 3.4E-4932 到 1.1E+4932 | 19 位小數 |
頭檔案 float.h 定義了宏,在程式中可以使用這些值和其他有關實數二進制表示的細節,下面的實體將輸出浮點型別占用的存盤空間以及它的范圍值:
#include <stdio.h>
#include <float.h>
int main()
{
printf("float 存盤最大位元組數 : %lu \n", sizeof(float));
printf("float 最小值: %E\n", FLT_MIN );
printf("float 最大值: %E\n", FLT_MAX );
printf("精度值: %d\n", FLT_DIG );
return 0;
}
%E 為以指數形式輸出單、雙精度實數,詳細說明查看 C 庫函式 - printf(),
當您在 Linux 上編譯并執行上面的程式時,它會產生下列結果:
float 存盤最大位元組數 : 4
float 最小值: 1.175494E-38
float 最大值: 3.402823E+38
精度值: 6
void 型別
void 型別指定沒有可用的值,它通常用于以下三種情況下:
| 序號 | 型別與描述 |
|---|---|
| 1 | 函式回傳為空 C 中有各種函式都不回傳值,或者您可以說它們回傳空,不回傳值的函式的回傳型別為空,例如 void exit (int status); |
| 2 | 函式引數為空 C 中有各種函式不接受任何引數,不帶引數的函式可以接受一個 void,例如 int rand(void); |
| 3 | 指標指向 void 型別為 void * 的指標代表物件的地址,而不是型別,例如,記憶體分配函式 void *malloc( size_t size ); 回傳指向 void 的指標,可以轉換為任何資料型別, |
如果現在還是無法完全理解 void 型別,不用太擔心,在后續的章節中將會詳細講解這些概念,
變數
變數是程式可操作的存盤區的名稱,C 中每個變數都有特定的型別,型別決定了變數存盤的大小和布局,該范圍內的值都可以存盤在記憶體中,運算子可應用于變數上,
變數的名稱可以由字母、數字和下劃線字符組成,它必須以字母或下劃線開頭,大寫字母和小寫字母是不同的,因為 C 是大小寫敏感的,基于前一章講解的基本型別,有以下幾種基本的變數型別:
| 型別 | 描述 |
|---|---|
| char | 通常是一個位元組(八位),這是一個整數型別, |
| int | 對機器而言,整數的最自然的大小, |
| float | 單精度浮點值,單精度是這樣的格式,1位符號,8位指數,23位小數,![]() |
| double | 雙精度浮點值,雙精度是1位符號,11位指數,52位小數,![]() |
| void | 表示型別的缺失, |
變數定義
變數定義就是告訴編譯器在何處創建變數的存盤,以及如何創建變數的存盤,變數定義指定一個資料型別,并包含了該型別的一個或多個變數的串列,如下所示:
type variable_list;
在這里,type 必須是一個有效的 C 資料型別,可以是 char、int、float、double 或任何用戶自定義的物件,variable_list 可以由一個或多個識別符號名稱組成,多個識別符號之間用逗號分隔,下面列出幾個有效的宣告:
int i, j, k;
char c, ch;
float f, salary;
double d;
變數可以在宣告的時候被初始化(指定一個初始值)
type variable_name = value;
下面列舉幾個實體:
extern int d = 3, f = 5; // d 和 f 的宣告與初始化
int d = 3, f = 5; // 定義并初始化 d 和 f
byte z = 22; // 定義并初始化 z
char x = 'x'; // 變數 x 的值為 'x'
沒有初始化時,變數的值時NULL(所有位元組的值都是 0)
變數宣告
變數宣告向編譯器保證變數以指定的型別和名稱存在,這樣編譯器在不需要知道變數完整細節的情況下也能繼續進一步的編譯,變數宣告只在編譯時有它的意義,在程式連接時編譯器需要實際的變數宣告,
變數的宣告有兩種情況:
- 1、一種是需要建立存盤空間的,例如:int a 在宣告的時候就已經建立了存盤空間,
- 2、另一種是不需要建立存盤空間的,通過使用extern關鍵字宣告變數名而不定義它, 例如:extern int a 其中變數 a 可以在別的檔案中定義的,
- 除非有extern關鍵字,否則都是變數的定義,
extern int i; //宣告,不是定義
int i; //宣告,也是定義
實體
嘗試下面的實體,其中,變數在頭部就已經被宣告,但是定義與初始化在主函式內:
#include <stdio.h>
// 函式外定義變數 x 和 y
int x;
int y;
int addtwonum()
{
// 函式內宣告變數 x 和 y 為外部變數
extern int x;
extern int y;
// 給外部變數(全域變數)x 和 y 賦值
x = 1;
y = 2;
return x+y;
}
int main()
{
int result;
// 呼叫函式 addtwonum
result = addtwonum();
printf("result 為: %d",result);
return 0;
}
執行結果如下:
result 為: 3
如果需要在一個源檔案中參考另外一個源檔案中定義的變數,我們只需在參考的檔案中將變數加上 extern 關鍵字的宣告即可,
addtwonum.c
#include <stdio.h>
/*外部變數宣告*/
extern int x ;
extern int y ;
int addtwonum()
{
return x+y;
}
test.c
#include <stdio.h>
/*定義兩個全域變數*/
int x=1;
int y=2;
int addtwonum();
int main(void)
{
int result;
result = addtwonum();
printf("result 為: %d\n",result);
return 0;
}
當上面的代碼被編譯和執行時,它會產生下列結果:
$ gcc addtwonum.c test.c -o main
$ ./main
result 為: 3
左值(Lvalues)和右值(Rvalues)
C 中有兩種型別的運算式:
- 左值(lvalue):指向記憶體位置的運算式被稱為左值(lvalue)運算式,左值可以出現在賦值號的左邊或右邊,
- 右值(rvalue):術語右值(rvalue)指的是存盤在記憶體中某些地址的數值,右值是不能對其進行賦值的運算式,也就是說,右值可以出現在賦值號的右邊,但不能出現在賦值號的左邊,
變數是左值,因此可以出現在賦值號的左邊,數值型的字面值是右值,因此不能被賦值,不能出現在賦值號的左邊,
// 下面是一個有效的陳述句;
int g = 20;
// 下面這個就不是一個有效的陳述句,會生成編譯時錯誤;
10 = 20;
參考自:https://www.runoob.com/cprogramming/c-tutorial.html
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/59752.html
標籤:C


