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