c語言怎麼定義宏定義

2019-10-19     科技i關注

宏定義是比較常用的預處理指令,即使用「標識符」來表示「替換列表」中的內容。標識符稱為宏名,在預處理過程中,預處理器會把源程序中所有宏名,替換成宏定義中替換列表中的內容。

常見的宏定義有兩種,不帶參數的宏定義和帶參數的宏定義。

宏定義可以幫助我們防止出錯,提高代碼的可移植性和可讀性等。

在軟體開發過程中,經常有一些常用或者通用的功能或者代碼段,這些功能既可以寫成函數,也可以封裝成為宏定義。那麼究竟是用函數好,還是宏定義好?這就要求我們對二者進行合理的取捨。

我們來看一個例子,比較兩個數或者表達式大小,首先我們把它寫成宏定義:

#define MAX( a, b) ( (a) > (b) (a) : (b) )

# 其次,把它用函數來實現:

int max( int a, int b)

{

return (a > b a : b)

}

很顯然,我們不會選擇用函數來完成這個任務,原因有兩個:首先,函數調用會帶來額外的開銷,它需要開闢一片棧空間,記錄返回地址,將形參壓棧,從函數返回還要釋放堆棧。這種開銷不僅會降低代碼效率,而且代碼量也會大大增加,而使用宏定義則在代碼規模和速度方面都比函數更勝一籌;其次,函數的參數必須被聲明為一種特定的類型,所以它只能在類型合適的表達式上使用,我們如果要比較兩個浮點型的大小,就不得不再寫一個專門針對浮點型的比較函數。反之,上面的那個宏定義可以用於整形、長整形、單浮點型、雙浮點型以及其他任何可以用「>」操作符比較值大小的類型,也就是說,宏是與類型無關的。

和使用函數相比,使用宏的不利之處在於每次使用宏時,一份宏定義代碼的拷貝都會插入到程序中。除非宏非常短,否則使用宏會大幅度增加程序的長度。

以上就是c語言怎麼定義宏定義的詳細內容,更多請關注其它相關文章!

更多技巧請《轉發 + 關注》哦!

文章來源: https://twgreatdaily.com/zh-cn/NbHx320BMH2_cNUgjOcE.html