c語言分配內存的方式
『壹』 在c語言中,如何給函數分配內存
不知lz有沒聽說過虛存一說,當源碼被編譯成二進制文件後,其中的變數,函數的虛擬地址,也就是內存空間中的地址就已確定,在運行時,操作系統為其分配物理內存並添加虛擬地址到物理地址的映射。
再說的多一點,一個進程(運行的程序)可分為若干段:代碼段、數據段、堆棧段等,其中函數所操作的空間(也就是局部變數的空間)就位於堆棧段,所謂函數分配內存大小,實際就是堆棧段指針的變化而已。
『貳』 c語言內存有幾種分配方式
基本上C程序的元素存儲在內存的時候有3種分配策略:
靜態分配
如果一個變數聲明為全局變數或者是函數的靜態變數,這個變數的存儲將使用靜態分配方式。靜態分配的內存一般會被編譯器放在數據段或代碼段來存儲,具體取決於實現。這樣做的前提是,在編譯時就必須確定變數的大小。 以IA32的x86平台及gcc編譯器為例,全局及靜態變數放在數據段的低端;全局及靜態常量放在代碼段的高端
自動分配
函數的自動局部變數應該隨著函數的返回會自動釋放(失效),這個要求在一般的體系中都是利用棧(Stack)來滿足的。相比於靜態分配,這時候,就不必絕對要求這個變數在編譯時就必須確定變數的大小,運行時才決定也不遲,但是C89仍然要求在編譯時就要確定,而C99放鬆了這個限制。但無論是C89還是C99,都不允許一個已經分配的自動變數運行時改變大小。
所以說C函數永遠不應該返回一個局部變數的地址。
要指出的是,自動分配也屬於動態分配,甚至可以用alloca函數來像分配堆(Heap)一樣進行分配,而且釋放是自動的。
動態分配
還有一種更加特殊的情況,變數的大小在運行時有可能改變,或者雖然單個變數大小不變,變數的數目卻有很大彈性,不能靜態分配或者自動分配,這時候可以使用堆(Heap)來滿足要求。ANSI C定義的堆操作函數是malloc、calloc、realloc和free。
使用堆(Heap)內存將帶來額外的開銷和風險。
『叄』 C語言中內存的分配方式有哪3種,用文字或表達式列出各自的一個例子
1.malloc(n*sizeof(int))
/*
請求n個連續的、每個長度為整型的空間,若成功返回這些空間的首地址,失敗返回0
*/
2.realloc(p,sizeof(int)*n)
/*
給一個已經分配了地址的指針重新分配空間,參數p為原有的空間地址*/
3.數組的定義。
『肆』 C語言中分配內存
要實現根據程序的需要動態分配存儲空間,就必須用到以下幾個函數
1、malloc函數
malloc函數的原型為:
void
*malloc
(u
igned
int
size)
其作用是在內存的動態存儲區中分配一個長度為size的連續空間。其參數是一個無符號整形數,返回值是一個指向所分配的連續存儲域的起始地址的指針。還有一點必須注意的是,當函數未能成功分配存儲空間(如內存不足)就會返回一個NULL指針。所以在調用該函數時應該檢測返回值是否為NULL並執行相應的操作。
下例是一個動態分配的程序:
#include
#include
main()
{
int
count,*array;
/*count是一個計數器,array是一個整型指針,也可以理解為指向一個整型數組的首地址*/
if((array(int
*)
malloc(10*sizeof(int)))==NULL)
{
printf("不能成功分配存儲空間。");
exit(1);
}
for
(count=0;count〈10;count++)
/*給數組賦值*/
array[count]=count;
for(count=0;count〈10;count++)
/*列印數組元素*/
printf("%2d",array[count]);
}
上例中動態分配了10個整型存儲區域,然後進行賦值並列印。例中if((array(int
*)
malloc(10*sizeof(int)))==NULL)語句可以分為以下幾步:
1)分配10個整型的連續存儲空間,並返回一個指向其起始地址的整型指針
2)把此整型指針地址賦給array
3)檢測返回值是否為NULL
2、free函數
由於內存區域總是有限的,不能不限制地分配下去,而且一個程序要盡量節省資源,所以當所分配的內存區域不用時,就要釋放它,以便其它的變數或者程序使用。這時我們就要用到free函數。
其函數原型是:
void
free(void
*p)
作用是釋放指針p所指向的內存區。
其參數p必須是先前調用malloc函數或calloc函數(另一個動態分配存儲區域的函數)時返回的指針。給free函數傳遞其它的值很可能造成死機或其它災難性的後果。
注意:這里重要的是指針的值,而不是用來申請動態內存的指針本身。例:
int
*p1,*p2;
p1=malloc(10*sizeof(int));
p2=p1;
……
free(p2)
/*或者free(p2)*/
malloc返回值賦給p1,又把p1的值賦給p2,所以此時p1,p2都可作為free函數的參數。
malloc函數是對存儲區域進行分配的。
free函數是釋放已經不用的內存區域的。
所以由這兩個函數就可以實現對內存區域進行動態分配並進行簡單的管理了。
『伍』 C語言中的動態內存分配的用法舉例
1、malloc函數:其作用是在內存的動態存儲區中分配一個長度為size的連續空間。其參數是一個無符號整形數,返回值是一個指向所分配的連續存儲域的起始地址的指針。
2、free函數:由於內存區域總是有限的,不能不限制地分配下去,而且一個程序要盡量節省資源,所以當所分配的內存區域不用時,就要釋放它,以便其它的變數或者程序使用。這時我們就要用到free函數。
3、calloc函數:其作用是在內存的動態存儲區中分配n個長度為 size 的連續空間。函數返回一個指向分配區域的起始位置的指針;如果分配不成功,則返回NULL。
(5)c語言分配內存的方式擴展閱讀:
函數運算符:
new
運算符new用於向系統申請動態存儲空間,並把首地址作為運算結果,它的使用形式為:
指針變數=new 數據類型;
例如:
int *p=new int
該語句的作用是會用new從內存中申請了一個int型變數(4個位元組),並將該變數的首地址賦給指針變數p。
new所建立的變數的初始值是任意的,也可在用new分配內存的同時進行初始化。使用形式為:
指針變數=new 數據類型(初始值)。
delete
堆內存可按照要求進行分配,程序對內存的需求量隨時會發生變化,有時程序在運行種可能會不再需要由new分配的內存空間,而且程序還未運行結束,這時就需要把先前佔用的內存空間釋放給堆內存,以後重新分配,供程序的其他部分使用。運算符delete用於釋放new分配的內存空間,刪除建立的對象,它的使用形式為:
delete指針變數;
其中的指針變數中保存著new分配的內存的首地址。
『陸』 c語言程序怎麼實現動態內存分配
1.p1=(int
*)malloc(10*sizeof(int));
//malloc
函數將會在動態存儲區中分配一個長度為
10*sizeof(int)的
<連續>
空間。
而且p1的值是
分配域的起始地址;這就有一點像數組名了。
2.例如
int
temp[10];
int
*ptemp;
ptemp=temp;
//得到數組的首地址。
這樣
ptemp
就可以
引用
數組的元素了。比如
ptemp[i];
當然
這是
固定分配內存的。
3.scanf("%d",&p1[btc]);
和
printf("%d",p1[btc]);
這兩個函數
中
p1
的作用
就
是相當於數組名。
引用動態的數組。
『柒』 C語言各種數據在內存中的分配方式,分別對程序的運行效率有哪些影響
從另一個角度,從變數值存在的作時間(即生存期)角度來分,可以分為靜態存儲方式
和動態存儲方式。
靜態存儲方式:是指在程序運行期間分配固定的存儲空間的方式。
動態存儲方式:是在程序運行期間根據需要進行動態的分配存儲空間的方式。
『捌』 c語言有幾種分配內存的方式,有什麼區別
一般而言,有兩種內存分配的方式。
1、在棧上分配。特點是當變數離開其作用域時,其內存即釋放了,例如局部變數、函數參數等都是在棧上分配的。
2、在堆上分配。特點是變數一直存在,例如new運算符分配出來的內存、全局變數和static靜態變數都是在堆上分配的。
『玖』 c語言中什麼是動態分配內存
c語言用函數malloc動態分配內存的,要用到指針,釋放內存是free指針
malloc
原型:extern
void
*malloc(unsigned
int
num_bytes);
用法:#include
<malloc.h>
或#include<stdlib.h>
功能:用於向內存申請空間,分配長度為num_bytes位元組的內存塊
說明:如果分配成功則返回指向被分配內存的指針,否則返回空指針NULL。
當內存不再使用時,應使用free()函數將內存塊釋放。
調用格式,
指針名=(指針所指對象的數據類型*)malloc(個數*sizeof(指針所指對象的數據類型)),其對應例子如下:
int
*p
=
(int
*)
malloc
(
n*
sizeof(int)
);
舉例:
//
malloc.c
#include
<syslib.h>
#include
<malloc.h>
main()
{
char
*p;
clrscr();
//
clear
screen
p=(char
*)malloc(100);
if(p)
printf("Memory
Allocated
at:
%x",p);
else
printf("Not
Enough
Memory!\n");
if(p)
free(p);
getchar();
return
0;
}