在程序中使用free釋放,否則該段內(nèi)存不會被釋放掉。
成都創(chuàng)新互聯(lián)公司憑借專業(yè)的設計團隊扎實的技術支持、優(yōu)質(zhì)高效的服務意識和豐厚的資源優(yōu)勢,提供專業(yè)的網(wǎng)站策劃、成都做網(wǎng)站、網(wǎng)站設計、外貿(mào)營銷網(wǎng)站建設、網(wǎng)站優(yōu)化、軟件開發(fā)、網(wǎng)站改版等服務,在成都十多年的網(wǎng)站建設設計經(jīng)驗,為成都數(shù)千家中小型企業(yè)策劃設計了網(wǎng)站。
C語言不會釋放。所謂動態(tài)內(nèi)存,是由malloc系列函數(shù)進行申請的內(nèi)存,除非在程序中使用free釋放,否則該段內(nèi)存不會被釋放掉。
標準庫中malloc函數(shù)的實現(xiàn)原理。要了解針對malloc的內(nèi)存存儲結構,malloc不像全局變量一樣,不是在編譯器編譯的時候就會分配內(nèi)存空間,而是在調(diào)用到malloc函數(shù)時才會分配空間。有時還會中途調(diào)用free函數(shù)釋放空間出來。
擴展資料
free:釋放malloc分配的存儲空間
malloc用于向系統(tǒng)申請一定數(shù)量的內(nèi)存,如果你的程序一味的申請內(nèi)存供自己使用,那么系統(tǒng)可分配給其它程序的內(nèi)存就會減少,到最后無內(nèi)存可用,最終導致系統(tǒng)運行緩慢,不穩(wěn)定等問題。顯然,這種只索取不奉獻的行為是不可取的因此,C語言提供了free函數(shù),用于向系統(tǒng)返還借用的內(nèi)存。
當忘記使用free釋放由malloc分配的內(nèi)存時,表明程序存在”內(nèi)存泄露“這一頑疾,因此對于上面的程序,在return 0之前,使用下面的代碼進行完善。
參考資料來源:百度百科—c語言
你的問題是剛剛學習指針的人都有的問題,需要從地址來認識這個問題,C語言的數(shù)據(jù)都是需要申請空間來存放的,有靜態(tài)和動態(tài)兩種,動態(tài)分配的空間大小可以按需要分配,并且可以回收,靜態(tài)是不可以回收的。
首先,分配動態(tài)的空間,指針P和空間的首地址是沒有直接的聯(lián)系的,只是為了手續(xù)要使用這個剛剛分配的空間才讓P指針指向這個剛剛分配的空間的首地址的話,如果還不理解,你可以反向想想如果你分配的這個空間,而不用P指針指向這個首地址,那么你如何使用這個空間呢?
void型是針對地址型的直接分配,為什么不是分配char的空間呢?因為C語言和硬件關系密切,
有寫硬件他的地址不是8位存儲的,是16位,或者是32位的,那么這個void就忽略了這個硬件地址寬位就分配100個地址就是了,然后,強制轉換成char的8位,如果硬件是16位了,那么,每個地址就會多分配了8位,而使用前8為來存儲空間了。
返回的指針是分配的100個地址的首地址,不是這個指針P,舉個例子吧,空間可以看做是一個隊伍,他本身就有一個領頭的人,那么P就是一個單獨的人,那么,我們?nèi)绻褚业竭@個隊伍,需要先找到隊伍的領頭人,領頭的人只在你申請的時候出現(xiàn)一次,后面,你就找不到他了,怎么辦?你把他電話給P吧,P可以找到他。呵呵。
如果還是不理解,那就不要理解了,建議去吧隊列的方式,用指針和動態(tài)分配內(nèi)存的方式實現(xiàn)一次,就知道了,不能照著書本抄,全部代碼要自己寫出來,就肯定理解了。
是的需要用malloc函數(shù)分配空間
例如:
先申請100個STUD大小的空間int n=100; STUD* stud=(STUD*)malloc(sizeof(STUD)*n);
再定義一個 i 來記錄從文本中讀取STUD的次數(shù)
如果 i 超過了 100 令 n=n*2,再申請n個STUD空間,把之前的空間用memcpy拷貝到新的空間
函數(shù)原型:
void*
malloc(int
size);
參數(shù):size
需要分配的內(nèi)存大小。
返回值:申請到的內(nèi)存地址(void*)。
說明:
如果返回NULL則說明申請失敗。
1 定義指針。
2 使用malloc函數(shù)分配內(nèi)存。
3 對數(shù)組進行訪問即可。
對于一維動態(tài)數(shù)組,直接定義一維指針,并分配內(nèi)存空間即可。
比如int類型的10個元素動態(tài)數(shù)組,寫作
int *a;
a = (int *)malloc(sizeof(int) * 10);
如果是多維數(shù)組,需要從高維向低維逐層分配。如二維數(shù)組10*100空間。
int **a;
int i;
a = (int **) malloc(sizeof(int *) * 10); // 先分配10個int*的空間。
for(i = 0; i 100; i ++)
a[i] = (int *)malloc(sizeof(int) * 100); // 對于每個int*,分配100個元素的空間。
這個是可以的,但是和其他網(wǎng)友說的一樣,內(nèi)存是線性的,當你在語言中分配一個多維數(shù)組的時候,編譯器其實也是分配線性內(nèi)存的,但是我們可以通過模擬來實現(xiàn)類似數(shù)組的操作,下面演示一個分配以及操作數(shù)組的實例(列數(shù)要固定,這里假設列數(shù)為4):
int _tmain(int argc, _TCHAR* argv[])
{
int (*p)[4] = (int (*)[4])0;
int row = 3;
int (*mem)[4] = (int (*)[4])0; // 定義數(shù)組首指針
mem = (int (*)[4])malloc(sizeof(int(*)[4]) * row); // 分配row行, 4列的數(shù)組
// 分別為二維數(shù)組的第一維各個元素賦值。
mem[0][0] = 1;
mem[0][1] = 2;
mem[0][2] = 3;
mem[0][3] = 4;
// 打印二維數(shù)組的各個元素的值
printf("%d, %d, %d, %d", mem[0][0], mem[0][1], mem[0][2], mem[0][3]);
free(mem);
return 0;
}
不過這里列數(shù)必須指定,還有一種方法,這種方法可以保證用戶輸入任意行或列,而不必要將列數(shù)定死,演示如下:
int getElement(int* arr, int colNum, int row, int col);
void setElement(int* arr, int colNum, int row, int col, int val);
int _tmain(int argc, _TCHAR* argv[])
{
int *arr = (int*)0;
int row = 3;
int col = 5;
//分配 row 行 col 列的整形數(shù)組
arr = (int*)malloc(sizeof(int) * col * row);
// 將最后一個元素值設置為100
setElement(arr, col, 2, 4, 100);
//輸出最后一個元素的值
printf("%d", getElement(arr, col, 2, 4));
free(arr);
return 0;
}
//各個參數(shù)說明如下:
//arr: 數(shù)組首地址
//colNum:數(shù)組列數(shù)
//row: 要取得的元素所在行
//col: 要取得的元素所在列
int getElement(int* arr, int colNum, int row, int col)
{
return *(arr + sizeof(int) * (row - 1) * colNum + col);
}
// 此函數(shù)用來設置指定行和列的元素的值:
//arr: 數(shù)組首地址
//colNum:數(shù)組列數(shù)
//row: 要取得的元素所在行
//col: 要取得的元素所在列
//val: 要設置的值
void setElement(int* arr, int colNum, int row, int col, int val)
{
*(arr + sizeof(int) * (row - 1) * colNum + col) = val;
}
其實歸根到底,還是對指針的操作,希望可以幫到你,呵呵。