c語言可變參數(shù)傳遞 如何在C語言中實現(xiàn)可變長度的參數(shù)?
如何在C語言中實現(xiàn)可變長度的參數(shù)?舉一下可變模板參數(shù)的例子吧(C 11及以上):可以獲得一堆 int 類型的參數(shù)中最小的一個(如果傳了奇怪的參數(shù)會報錯),其他類型同理。如果不用C 11的話可能沒有
如何在C語言中實現(xiàn)可變長度的參數(shù)?
舉一下可變模板參數(shù)的例子吧(C 11及以上):
c語言傳遞變長參數(shù)?
二維數(shù)組做函數(shù)參數(shù)時,形參的語法形式是:類型說明符 形參名[ ][常量表達(dá)式M]形參數(shù)組可以省略一維的長度。由于實參代表了數(shù)組名,是"地址傳遞",二維數(shù)組在內(nèi)存中是按行存儲的。在形參中,就必須指明列的個數(shù),才能保證實參數(shù)組與形參數(shù)組中的數(shù)據(jù)一一對應(yīng),所以,形參數(shù)組中第二維的長度是不能省略的。調(diào)用函數(shù)時,與形參數(shù)組相對應(yīng)的實參數(shù)組必須也是一個二維數(shù)組,而且它的第二維的長度與形參數(shù)組的第二維的長度必須相等。函數(shù)sum2d(int rows, int cols, int ar[rows][cols]) 的第三個參數(shù)數(shù)組ar的第二維必須給一個常數(shù)。
C語言中可變參數(shù)的用法?
C語言可變參數(shù)的定義采用3個點(...)表示。
比如:
void printf(const char* fmt, ...)
通過以下方法進(jìn)行提取參數(shù):
va_start
va_arg
va_end
既然C語言函數(shù)的局部變量會被釋放,那為什么函數(shù)還可以把它return返回呢?
看了底下兄弟的答復(fù),只能說答對了一半。
真正的原因在于ABI(應(yīng)用程序二進(jìn)制接口)。
ABI定義了與系統(tǒng)交互的細(xì)節(jié):如數(shù)據(jù)類型、大小和對齊;調(diào)用約定(控制函數(shù)的參數(shù)的傳遞方向、可變長度處理、堆棧清理主體以及如何接受返回值等);系統(tǒng)調(diào)用的編碼和一個應(yīng)用如何向操作系統(tǒng)進(jìn)行系統(tǒng)調(diào)用;以及在一個完整的操作系統(tǒng)ABI中,目標(biāo)文件的二進(jìn)制格式、程序庫等等。一個完整的ABI,像Intel二進(jìn)制兼容標(biāo)準(zhǔn) (iBCS),允許支持它的操作系統(tǒng)上的程序不經(jīng)修改在其他支持此ABI的操作體統(tǒng)上運行。
其他的 ABI 標(biāo)準(zhǔn)化細(xì)節(jié)還包括 C 名稱修飾 ,和同一個平臺上的編譯器之間的調(diào)用約定,但是不包括跨平臺的兼容性。
至于底下兄弟所說的EAX保存返回值,這個只是X86的ABI規(guī)范,在PowerPC等其他CPU架構(gòu)平臺,實現(xiàn)是不一樣的!——PowerPC下,返回值是保存在R3寄存器中的