發布時間:2021-10-27 16:46:33來源:有考培訓網綜合
溫州達內C++開發培訓機構怎么樣?作為國內IT培訓的實力品牌,達內集團的每一名員工都以"幫助每一個學員成就夢想"為己任,也正因為達內人的執著與努力,達內堅持為社會輸送合格人才,為中國IT行業的發展做出了貢獻。達內特色辦學,開設了豐富多樣的IT技術課程。
(一)什么是宏定義:
1.宏定義“像”函數;
2.宏定義不是函數,因而需要括上所有參數;
3.宏定義可能產生副作用;
例如:
#define MIN(a,b) ((a) < (b) ? (a) : (b))
(二)void和void 指針深層探討
規則:在C語言中,凡是不加返回值類型限定的函數,就會被編譯器作為返回整形值處理,但很多程序員卻誤認為其為void類型。
1.任何類型的指針都可以直接賦值給void*類型的指針,無需進行強制類型轉換。但是void*指針卻不可以不進行強制類型轉換而直接就賦值給其他類型的指針。
2.如果函數沒有返回值,應聲明為void類型。
3.如果函數無參數,那么應聲明其參數為void類型。在C語言中可以給無參數的函數傳送任意類型的參數,但是在C++中不能向無參數的函數傳送任何參數,錯誤提示:function does not take 1 parameters.所以無論是C還是C++,若函數不接受任何參數,應將其聲明為void類型。
4按照ANSI(American National Standards Institute)標準,不能對void指針進行算法操作,這是因為ANSI標準認定:進行算法操作的指針必須是確定知道其指向類型大小的。例如:
int *ptr;
ptr++;
ptr++的結果是使其增大sizeof(int).
但是GNU則不這么認定,它指定void*的算法操作和char*一致。
5.如果函數的參數可以是任意類型指針,那么應將其聲明為void*類型。
典型的如內存操作函數:
void * memcpy(void *dest, const void *src, size_t len);
void * memset(void *buffer, int c,size_t num);
這樣,任何類型的指針都可以傳入memcpy和memset中,這也真實的體現了內存操作函數的意義,因為它操作的對象僅僅是一片內存,而無論這片內存是什么類型!
6.void不能代表一個真實的變量,如void a;錯誤
(三)內存分配方式
內存分配方式有3中:
1. 從靜態存儲區域分配。內存在程序編譯的時候就已經分配好,這塊內存在程序的整個運行期間都存在,例如全局變量,static變量。
2.在棧上創建,在執行函數時,函數內部的局部變量的存儲單元都是可以在棧上創建的。函數執行結束時這些存儲單元自動被釋放,棧內存分配運算內置于處理器的指令集中,效率很高,但是分配的內存容量有限。
3。在堆上分配,亦稱動態內存分配,程序在運行的時候用malloc或new申請任意多少的內存,程序員自己負責在何時用free或delete釋放內存,動態內存的生存期由我們決定,使用靈活,但是容易出錯。
(四)內存操作注意事項
1、用malloc或new申請內存之后,應該立即檢查指針值是否為NULL,防止使用指針值為NULL的內存。
2、不要忘記為數組和動態內存賦初值,防止將未被初始化的內存作為右值使用。
3、避免數組或指針的下標越界,特別要當心發生多1或者少1的操作。
4、動態內存的申請和釋放必須配對,防止內存泄露。
5、用free或delete釋放了內存之后,立即將指針設置為NULL,防止產生"野指針"."野指針"不是NULL指針,是指向”垃圾“內存的指針。
(五)如何判斷大小端格式
編寫一個C函數,若處理器是big_endian的,則返回0,若是little_endian的,則返回1;
int checkCPU(void){ union w{
int a;
char b;
}c;
c.a = 0x1234;
return(c.b == 0x34);