C 語(yǔ)言中的 maclloc free()
在幾乎所有的情況下, C 語(yǔ)言都可以自動(dòng)的來(lái)分配內(nèi)存,這不需要你的參與。這很高效,也很安全。這也是目前主流語(yǔ)言所采取的策略。但是 C 語(yǔ)言除了系統(tǒng)自動(dòng)分配和回收內(nèi)存,還可以自己手動(dòng)來(lái)分配和回收內(nèi)存,讓你的程序更具有靈活性。
1. 動(dòng)態(tài)分配內(nèi)存
int *x;
x = (int *)maclloc(32);
maclloc
函數(shù)的參數(shù)是分配的內(nèi)存的大小,這個(gè)值我們也可以根據(jù)不同變量類型通過(guò) sizeof
這個(gè)函數(shù)來(lái)獲得。其返回值是一個(gè)無(wú)類型的指針。所以這里我們用了顯示的類型轉(zhuǎn)換,將其轉(zhuǎn)換與指針變量類型相同的指針。
2. 回收動(dòng)態(tài)分配的內(nèi)存
回收動(dòng)態(tài)分配的內(nèi)存需要傳入指針變量即可。
free(x);
這樣就釋放了我們之前動(dòng)態(tài)分配的內(nèi)存空間。
3. 示例程序
#include <stdio.h>
#include <stdlib.h>
int main()
{
int *x;
printf("x value: %p, x address: %p, *x value: %d\n", x, &x, *x);
x = (int *)malloc(sizeof(x));
printf("x value: %p, x address: %p, *x value: %d\n", x, &x, *x);
*x = 10;
printf("x value: %p, x address: %p, *x value: %d\n", x, &x, *x);
free(x);
return 0;
}
運(yùn)行結(jié)果:
x value: 0x7fffeac6bd50, x address: 0x7fffeac6bc60, *x value: 1
x value: 0x7fffe3916270, x address: 0x7fffeac6bc60, *x value: 0
x value: 0x7fffe3916270, x address: 0x7fffeac6bc60, *x value: 10
程序中聲明了一個(gè)整數(shù)型的指針,然后對(duì)這個(gè)指針?lè)峙淞艘粔K內(nèi)存。把這個(gè)分配好的內(nèi)存地址給了指針變量。然后對(duì)這個(gè)地址所表示的變量進(jìn)行賦值。最后再回收分配的內(nèi)存。
4. 小結(jié)
動(dòng)態(tài)內(nèi)存分配可以說(shuō)是 C 語(yǔ)言程序員的噩夢(mèng)。我們可能會(huì)遇到如果分配了內(nèi)存,但是在最后沒(méi)有回收內(nèi)存。這種情況就如同內(nèi)存空洞存在,會(huì)不斷的使系統(tǒng)的可用內(nèi)存減少,因此稱之為內(nèi)存泄露。這是非常常見(jiàn)的內(nèi)存分配的錯(cuò)誤。很多著名的軟件也都會(huì)存在這種問(wèn)題。最簡(jiǎn)單的解決辦法就是通過(guò)定期重啟程序來(lái)解決。還有一種常見(jiàn)錯(cuò)誤就是使用沒(méi)有成功分配的內(nèi)存地址。這也會(huì)引起莫名的錯(cuò)誤。
同時(shí)使用分配內(nèi)存的函數(shù)會(huì)消耗一定的資源,因?yàn)檫@會(huì)讓 C 語(yǔ)言調(diào)用與系統(tǒng)之間的 API ,會(huì)拖慢程序的運(yùn)行。大量的調(diào)用會(huì)產(chǎn)生性能問(wèn)題。
所以在進(jìn)行涉及計(jì)算機(jī)或者其他設(shè)備硬件資源操作的時(shí)候,一定要謹(jǐn)慎。因?yàn)檫@些資源是有限的,一旦被占用了,可利用的資源數(shù)量就會(huì)減少。直至資源的耗盡。