巨集定義,const 與 sizeof

2021-07-03 01:55:24 字數 1507 閱讀 9171

1) #define是預處理指令,在編譯預處理時進行簡單的替換,不作正確性檢查,不關含義是否正確照樣帶入,只有在編譯已被展開的源程式時才會發現可能的錯誤並報錯。例如:

#define pi 3.1415926

程式中的:area=pi*r*r 會替換為3.1415926*r*r

如果你把#define語句中的數字9 寫成字母g 預處理也照樣帶入。

2)typedef是在編譯時處理的。它在自己的作用域內給乙個已經存在的型別乙個別名,但是you cannot use the typedef specifier inside a function definition。

3)typedef int * int_ptr;

與#define int_ptr int * 

作用都是用int_ptr代表 int * ,但是二者不同,正如前面所說 ,#define在預處理 時進行簡單的替換,而typedef不是簡單替換 ,而是採用如同定義變數的方法那樣來宣告一種型別。也就是說;

//refer to (xzgyb(老達摩))

#define int_ptr int *

int_ptr a, b; //相當於int * a, b; 只是簡單的巨集替換

typedef int* int_ptr;

int_ptr a, b; //a, b 都為指向int的指標,typedef為int* 引入了乙個新的助記符

這也說明了為什麼下面觀點成立

//qunkangli(維護成本與程式設計師的創造力的平方成正比)

typedef int * pint ;

#define pint int *

那麼:const pint p ;//p不可更改,但p指向的內容可更改

const pint p ;//p可更改,但是p指向的內容不可更改。

pint是一種指標型別 const pint p 就是把指標給鎖住了 p不可更改

而const pint p 是const int * p 鎖的是指標p所指的物件。

3)也許您已經注意到#define 不是語句 不要在行末加分號,否則 會連分號一塊置換。

#define只是做簡單的文字替換

1. 可以定義 const 常量,也可以修飾函式的引數和返回值,甚至函式的定義體。

2. const 和 #define

const 常量有資料型別,而巨集常量沒有資料型別。編譯器可以對前者進行型別安全檢查,而對後者只能進行字元替換,沒有型別安全檢查。

在c++ 程式中只使用 const 常量而不使用巨集常量,即 const 常量完全取代巨集常量

1. 指標的大小是個定值,佔 4 位元組

2. int 整型,佔 4 位元組

3. bool 型,佔 1 位元組

4. float 型,佔 4 位元組

例如:

#include using namespace std;

class a1

;class a3

;class a4

;int main()

const常量與巨集定義區別

1 編譯器處理方式不同 define巨集是在預處理階段展開。const常量是編譯執行階段使用。2 型別和安全檢查不同 define巨集沒有型別,不做任何型別檢查,僅僅是展開。const常量有具體的型別,在編譯階段會執行型別檢查。3 儲存方式不同 define巨集僅僅是展開,有多少地方使用,就展開多少...

const常量與巨集定義區別

1 編譯器處理方式不同 define巨集是在預處理階段展開。const常量是編譯執行階段使用。2 型別和安全檢查不同 define巨集沒有型別,不做任何型別檢查,僅僅是展開。const常量有具體的型別,在編譯階段會執行型別檢查。3 儲存方式不同 define巨集僅僅是展開,有多少地方使用,就展開多少...

const定義常量與巨集定義的區別!!!

巨集定義語法格式 define 巨集名稱 巨集值 不加分號,變數名一般設為大寫 巨集的替換與計算 舉乙個例子 define n 3 1 define y n n 1 n 若執行語句 z 2 n y 5 1 後 z 的值為多少?z 2 3 1 3 1 1 5 1 60 巨集的替換在 執行的預編譯階段,...