我看的是劉宗田等譯,目前覺得這本書一般。
1.對象的演化(完全可以跳過,譯的太差)
2.資料抽象
(1)提高編程效率的方法之理就是使用他人編好的代碼,即庫。
(2)聲明與定義:聲明是向電腦介紹名字,它說這個名字是什麼意思;定義是為這個名字分配儲存空間。
(3)函式宣告時,參數名可以不給出,但定義時必須給出。
3.動態儲存裝置分配malloc/calloc/realloc/free
三個函數的申明分別是:
void* realloc(void* ptr, unsigned newsize);
void* malloc(unsigned size);
void* calloc(size_t numElements, size_t sizeOfElement);
都在stdlib.h函數庫內
它們的傳回值都是請求系統分配的地址,如果請求失敗就返回NULL
malloc用於申請一段新的地址,參數size為需要記憶體空間的長度,如:
char* p;
p=(char*)malloc(20);
calloc與malloc相似,參數sizeOfElement為申請地址的單位元素長度,numElements為元素個數,如:
char* p;
p=(char*)calloc(20,sizeof(char));
這個例子與上一個效果相同
realloc是給一個已經分配了地址的指標重新分配空間,參數ptr為原有的空間地址,newsize是重新申請的地址長度
如:
char* p;
p=(char*)malloc(sizeof(char)*20);
p=(char*)realloc(p,sizeof(char)*40);
注意,這裡的空間長度都是以位元組為單位。
C語言的標準記憶體配置函數:malloc,calloc,realloc,free等。
malloc與calloc的區別為1塊與n塊的區別:
malloc調用形式為(類型*)malloc(size):在記憶體的動態儲存裝置區中分配一塊長度為“size”位元組的連續地區,返回該地區的首地址。
calloc調用形式為(類型*)calloc(n,size):在記憶體的動態儲存裝置區中分配n塊長度為“size”位元組的連續地區,返回首地址。
realloc調用形式為(類型*)realloc(*ptr,size):將ptr記憶體大小增大到size。
free的調用形式為free(void*ptr):釋放ptr所指向的一塊記憶體空間。
C++中為new/delete函數。
如果調用成功,函數malloc()和函數calloc()都將返回所分配的記憶體空間的首地址。
函數malloc()和函數calloc() 的主要區別是前者不能初始化所分配的記憶體空間,而後者能。如果由malloc()函數分配的記憶體空間原來沒有被使用過,則其中的每一位可能都是0;反之, 如果這部分記憶體曾經被分配過,則其中可能遺留有各種各樣的資料。也就是說,使用malloc()函數的程式開始時(記憶體空間還沒有被重新分配)能正常進行,但經過一段時間(記憶體空間還已經被重新分配)可能會出現問題。
函數calloc() 會將所分配的記憶體空間中的每一位都初始化為零,也就是說,如果你是為字元類型或整數類型的元素分配記憶體,那麽這些元素將保證會被初始化為0;如果你是為指標類型的元素分配記憶體,那麽這些元素通常會被初始化為空白指標;如果你為實型資料分配記憶體,則這些元素會被初始化為浮點型的零。
malloc 向系統申請分配指定size個位元組的記憶體空間。傳回型別是 void* 類型。void* 表示未確定類型的指標。C,C++規定,void* 類型可以強制轉換為任何其它類型的指標。
從函式宣告上可以看出。malloc 和 new 至少有兩個不同: new 返回指定類型的指標,並且可以自動計算所需要大小。比如:
int *p;
p = new int; //傳回型別為int* 類型(整數型指標),分配大小為 sizeof(int);
或:
int* parr;
parr = new int [100]; //傳回型別為 int* 類型(整數型指標),分配大小為 sizeof(int) * 100;
而 malloc 則必須由我們計算要位元組數,並且在返回後強行轉換為實際類型的指標。
int* p;
p = (int *) malloc (sizeof(int));
第一、malloc 函數返回的是 void * 類型,如果你寫成:p = malloc (sizeof(int)); 則程式無法通過編譯,報錯:“不能將 void* 賦值給 int * 類型變數”。所以必須通過 (int *) 來將強制轉換。
第二、函數的實參為 sizeof(int) ,用於指明一個整型資料需要的大小。如果你寫成:
int* p = (int *) malloc (1);
代碼也能通過編譯,但事實上只分配了1個位元組大小的記憶體空間,當你往裡頭存入一個整數,就會有3個位元組無家可歸,而直接“住進鄰居家”!造成的結果是後面的記憶體中原有資料內容全部被清空。
malloc 也可以達到 new [] 的效果,申請出一段連續的記憶體,方法無非是指定你所需要記憶體大小。
比如想分配100個int類型的空間:
int* p = (int *) malloc ( sizeof(int) * 100 ); //分配可以放得下100個整數的記憶體空間。
另外有一點不能直接看出的區別是,malloc 只管分配記憶體,並不能對所得的記憶體進行初始化,所以得到的一片新記憶體中,其值將是隨機的。
ps:熱忱歡迎朋友們進行評論,對理解不足之處加以指點