C語言的那些小秘密之記憶體分配

2022-04-01 16:03:03 字數 1718 閱讀 8967

realloc()函式

原型:extern void *realloc(void *mem_address, unsigned int newsize);

語法:指標名=(資料型別*)realloc(要改變記憶體大小的指標名,新的大小)。

標頭檔案:#include 有些編譯器需要#include ,在tc2.0中可以使用alloc.h標頭檔案

功能:先按照newsize指定的大小分配空間,將原有資料從頭到尾拷貝到新分配的記憶體區域,而後釋放原來mem_address所指記憶體區域,同時返回新分配的記憶體區域的首位址。即重新分配儲存器塊的位址。

返回值:如果重新分配成功則返回指向被分配記憶體的指標,否則返回空指標null。

注意:這裡原始記憶體中的資料還是保持不變的。當記憶體不再使用時,應使用free()函式將記憶體塊釋放。

malloc()函式

原型:extern void *malloc(unsigned int num_bytes);

標頭檔案:在tc2.0中可以用malloc.h或 alloc.h (注意:alloc.h 與 malloc.h 的內容是完全一致的),而在visual c++6.0中可以用malloc.h或者stdlib.h。

功能:分配長度為num_bytes位元組的記憶體塊

返回值:如果分配成功則返回指向被分配記憶體的指標,否則返回空指標null。當記憶體不再使用時,應使用free()函式將記憶體塊釋放。

說明:關於該函式的原型,在舊的版本中malloc返回的是char型指標,新的ansic標準規定,該函式返回為void型指標,因此必要時要進行型別轉換。

calloc()函式

calloc是乙個c語言函式

功 能: 在記憶體的動態儲存區中分配n個長度為size的連續空間,函式返回乙個指向分配起始位址的指標;如果分配不成功,返回null。

跟malloc的區別:

calloc在動態分配完記憶體後,自動初始化該記憶體空間為零,而malloc不初始化,裡邊資料是隨機的垃圾資料。

用 法: void *calloc(unsigned n,unsigned size);

標頭檔案:stdlib.h或malloc.h

#include

#include

int main(void)

for (i = 0; i < num; i++)

for (i = 0; i < num; i++)

p[i] = i+1;

for (i = 0; i < num; i++)

printf("%d\t", p[i]);

printf("\n------------------\n");

num = 4;

p = (long *)realloc(p, num*sizeof(long));

for (i = 0; i < num; i++)

printf("%d\t", p[i]);

printf("\n------------------\n");

num = 10;

p = (long *)realloc(p, num*sizeof(long));

for (i = 0; i < num; i++)

printf("%d\t", p[i]);

free(p);

free(p1);

getchar();

return 0;

}**: 

C語言的那些小秘密之指標(一)

懂得c語言的人都知道,c語言之所以強大,以及其自由性,絕大部分體現在其靈活的指標運用上。因此,說指標是c語言的靈魂,一點都不為過。所以從我的標題加了個 一 也可以看出指標的重要性,我盡可能的向大家交代清楚我對於指標的理解。所以在講解的過程中我盡可能的用 加文字的描述方式,通過 的分析來加深我們對於指...

C語言的那些小秘密之函式指標

我們經常會聽到這樣的說法,不懂得函式指標就不是真正的c語言高手。我們不管這句話對與否,但是它都從側面反應出了函式指標的重要性,所以我們還是有必要掌握對函式指標的使用。先來看看函式指標的定義吧。函式是由執行語句組成的指令序列或者 這些 的有序集合根據其大小被分配到一定的記憶體空間中,這一片記憶體空間的...

C語言的那些小秘密之函式指標

函式是由執行語句組成的指令序列或者 這些 的有序集合根據其大小被分配到一定的記憶體空間中,這一片記憶體空間的起始位址就成為函式的位址,不同的函式有不同的函式位址,編譯器通過函式名來索引函式的入口位址,為了方便操作型別屬性相同的函式,c c 引入了函式指標,函式指標就是指向 入口位址的指標,是指向函式...