內存分配函數malloc calloc realloc free
堆內存分配函數 | 說明 |
---|---|
void * malloc(int n) | 形參n為要求分配的字節數。需要注意的是,malloc函數分配得到的內存空間是未初始化的。必須使用memset函數來初始化。 |
calloc(10, sizeof(char)); | 兩個參數:單元數,單元的size。分配內存,并清理內存。初始內容全部為0; |
realloc(p,10); | 調整內存的大??; 分配的內存空間并未初始化;使用新返回的地址, |
free(void * p) | 釋放指針p所指向的堆上的空間; |
malloc() 不對分配的內存空間做初始化,內存上原有的值不會被清理。
realloc(),在原有內存基礎之上,在堆中間增加連續的內存,如果原有內存沒有連續空間可擴展,則新分配一個空間,將原有內存copy到新空間,然后釋放原有內存。
1
2
3
4
5
|
p = malloc (10); //直接申請4k的空間。內存頁大小。 返回值是無類型指針void *,可以強制轉換。 free (p); char *p = calloc (10, sizeof ( char )); //兩個參數:單元數,單元的size。 分配內存,并清理內存 char *p2 = realloc (p,10); // 在原有內存基礎之上,在堆中間增加連續的內存,如果原有內存沒有連續空間可擴展,則新分配一個空間,將原有內存copy到新空間,然后釋放原有內存。 char *p2 = realloc (NULL,20); //此時,和malloc等價 |
realloc和malloc一樣,只分配內存,不清理,需要手動初始化。
// 復雜數據內存放在堆里面
內存操作函數 memset memcpy memmove
1
2
3
4
|
memset (buf,0, sizeof (buf)); //三個參數分別是:要設置的內存地址,要設置的值,值占的內存的字節數。 將一塊內存初始化為0最長見的方法。 extern void * memset ( void *buffer, int c, int count) memcpy ( void *dest, void *src,unsigned int count); //將buf1的地址的內存內容全部拷貝到buf2,拷貝大小為第三個參數:字節一定確保內存區域沒有內存區域重疊。 memmove (buf2, buf1, sizeof (buf1)); //內存移動,并沒有改變原始內存的值。 |
二維動態數組的建立和釋放
在創建動態數組的過程中我們要遵循一個原則,那就是在創建的時候從外層往里層,逐層創建;
而釋放的時候從里層往外層,逐層釋放。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
|
int main() { int num1,num2; num1 = 4; num2 = 5; int **array = ( int **) calloc (num1, sizeof ( int *)); //開辟空間,num1個一維int*型指針 for ( int i=0;i<num1;i++) { array[i] = ( int *) calloc (num2, sizeof ( int )); //給每個int *型指針分配內存 } for ( int i=0;i<num1;i++) { for ( int j=0;j<num2;j++) { array[i][j] =i*num2+j+1; printf ( "%d\t" ,array[i][j]); } printf ( "\n" ); } for ( int i=0;i<num1;i++) { free (array[i]); // 釋放第二維的內存 } free (array); // 釋放第一維的內存 return 0; } |
總結
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關注服務器之家的更多內容!
原文鏈接:https://blog.csdn.net/weixin_40877998/article/details/120244800