C/C++: Inline function, calloc 對比 malloc
Inline function is like a macro definition. When it was be called in another function, the control right will not be changed to this function. The compiler will just replace the line of inline function with the actual content of the function. We use inline function to eliminate the cost of calling a function.
內(nèi)聯(lián)函數(shù)從源代碼層看,有函數(shù)的結(jié)構(gòu),而在編譯后,卻不具備函數(shù)的性質(zhì)。內(nèi)聯(lián)函數(shù)不是在調(diào)用時發(fā)生控制轉(zhuǎn)移,而是在編譯時將函數(shù)體嵌入在每一個調(diào)用處。編譯時,類似宏替換,使用函數(shù)體替換調(diào)用處的函數(shù)名。內(nèi)聯(lián)擴展是用來消除函數(shù)調(diào)用時的時間開銷。它通常用于頻繁執(zhí)行的函數(shù)。 一個小內(nèi)存空間的函數(shù)非常受益。
帶參數(shù)的宏定義的一般形式如下:
#define <宏名>(<參數(shù)表>) <宏體>
其中, <宏名>是一個標識符,<參數(shù)表>中的參數(shù)可以是一個,也可以是多個,視具體情況而定,當(dāng)有多個參數(shù)的時候,每個參數(shù)之間用逗號分隔。<宏體>是被替換用的字符串,宏體中的字符串是由參數(shù)表中的各個參數(shù)組成的表達式。
#define SUB(a,b) a-b
如果在程序中出現(xiàn)如下語句:
result=SUB(2, 3);
則被替換為:
result=2-3;
calloc與malloc的區(qū)別:
calloc在動態(tài)分配完內(nèi)存后,自動初始化該內(nèi)存空間為零,而malloc不初始化,里邊數(shù)據(jù)是隨機的垃圾數(shù)據(jù)。
用法:
void *calloc(size_t n, size_t size);
一般使用后要使用 free(起始地址的指針) 對內(nèi)存進行釋放,不然內(nèi)存申請過多會影響計算機的性能,以至于得重啟電腦。如果使用過后不清零,還可以使用指針對該塊內(nèi)存進行訪問.
相關(guān)文章
C++非繼承時函數(shù)成員訪問屬性和類繼承過程中的訪問控制
這篇文章主要介紹了C++非繼承時函數(shù)成員訪問屬性和類繼承過程中的訪問控制,非繼承時,protected成員和private成員沒有任何區(qū)別,都是類內(nèi)部可以直接訪問它們、類外部的類對象不可訪問它們、類內(nèi)部的類對象可以訪問它們,更多詳細內(nèi)容請參考下面相關(guān)資料2022-03-03
C++ 網(wǎng)絡(luò)連通性檢測的實現(xiàn)方法
這篇文章主要介紹了C++ 網(wǎng)絡(luò)連通性檢測的實現(xiàn)方法的相關(guān)資料,這里提供實例幫助大家實現(xiàn)這樣的功能,需要的朋友可以參考下2017-09-09
使用mmap實現(xiàn)大文件的復(fù)制(單進程和多進程)
這篇文章主要為大家詳細介紹了使用mmap實現(xiàn)大文件的復(fù)制,單進程與多進程的兩種情況,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-10-10
C++實現(xiàn)LeetCode(143.鏈表重排序)
這篇文章主要介紹了C++實現(xiàn)LeetCode(143.鏈表重排序),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下2021-07-07

