c语言的内存分配
⑴ 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语言结构体在内存中的分配
因为内存对齐。
为了CPU更快地寻址,编译器会进行内存对齐。
char
c1;
//分配1字节空间
char
c2;
//分配1字节空间
short
s;
//上面的两个char占用空间刚好等于一个short,不会发生对齐,分配2字节空间
int
i;
//上面的两个char一个short占用空间刚好等于一个int,不会发生对齐,分配4字节空间
因此最后结构体test2的size为8字节
char
c1;
//分配1字节空间
short
s;
//地址未对齐,会发生内存对齐,补齐1字节的空间,然后再为short分配2字节空间
char
c2;
//分配1字节空间
int
i;
//地址未对齐,会发生内存对齐,补齐3字节的空间,然后再为int分配4字节空间
因此最后结构体test1的size为1+1(补齐)+2+1+3(补齐)+4=12字节
欲知详情,请网络“内存对齐”,这里不再详述。
⑶ 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语言中,如何给函数分配内存
不知lz有没听说过虚存一说,当源码被编译成二进制文件后,其中的变量,函数的虚拟地址,也就是内存空间中的地址就已确定,在运行时,操作系统为其分配物理内存并添加虚拟地址到物理地址的映射。
再说的多一点,一个进程(运行的程序)可分为若干段:代码段、数据段、堆栈段等,其中函数所操作的空间(也就是局部变量的空间)就位于堆栈段,所谓函数分配内存大小,实际就是堆栈段指针的变化而已。
⑸ C语言中的内存分配问题
为了跨平台,因为不同得编译器int的大小是不相同的。有的16位有的32位。sizeof(int)是取得当前的int大小,乘以N就是总共申请的空间大小了。
malloc返回一个指针但是这个指针的类型是void
*,也就是它不知道是什么类型的指针。但是你知道里面的元素是int类型,所以(int*)强制转换成int的指针。
⑹ c语言数组在内存中是怎么分配的
C语言中内存为分三类:栈区、堆区、静态数据区。
局部变量在栈上分配,函数调用前的栈指针,要和函数返回后的栈指针一样,否则就会出错。
void test(void)
{
char i,a[10];
printf("0x%x", &i);
printf("0x%x", a);
printf("0x%x", a+1);
printf("0x%x", a+2);
printf("0x%x", a+3);
}
(6)c语言的内存分配扩展阅读
c语言数组在内存分配
示例:
#include<stdio.h>
int main()
{
int a[4] = {11,12,13,14};
int b[4] = {21,22,23,24};
int *pa = &a;
int i = 0;
while(i<8)
{
i++;
printf("now *p value = %d and",*pa);
printf("p addr value = %d ",pa);
pa++;
}
return 0;
}
⑺ c语言内存有几种分配方式
基本上C程序的元素存储在内存的时候有3种分配策略:
静态分配
如果一个变量声明为全局变量或者是函数的静态变量,这个变量的存储将使用静态分配方式。静态分配的内存一般会被编译器放在数据段或代码段来存储,具体取决于实现。这样做的前提是,在编译时就必须确定变量的大小。 以IA32的x86平台及gcc编译器为例,全局及静态变量放在数据段的低端;全局及静态常量放在代码段的高端
自动分配
函数的自动局部变量应该随着函数的返回会自动释放(失效),这个要求在一般的体系中都是利用栈(Stack)来满足的。相比于静态分配,这时候,就不必绝对要求这个变量在编译时就必须确定变量的大小,运行时才决定也不迟,但是C89仍然要求在编译时就要确定,而C99放松了这个限制。但无论是C89还是C99,都不允许一个已经分配的自动变量运行时改变大小。
所以说C函数永远不应该返回一个局部变量的地址。
要指出的是,自动分配也属于动态分配,甚至可以用alloca函数来像分配堆(Heap)一样进行分配,而且释放是自动的。
动态分配
还有一种更加特殊的情况,变量的大小在运行时有可能改变,或者虽然单个变量大小不变,变量的数目却有很大弹性,不能静态分配或者自动分配,这时候可以使用堆(Heap)来满足要求。ANSI C定义的堆操作函数是malloc、calloc、realloc和free。
使用堆(Heap)内存将带来额外的开销和风险。
⑻ C语言的内存分配,这些对吗
void
*
malloc(int
size)
类型
*指针变量名=(类型名
*)malloc(sizeof(类型名)
*个数);
举例:
int
*p=(int
*)malloc(sizeof(int)
*
10);
分配10个int大小的内存
char
*pstr=(char
*)malloc(sizeof(char)
*
100);
⑼ 关于c语言动态内存分配的问题
要实现动态内存的分配,除了利用含指针成员的结构体之外,还需利用C语言提供的几个标准库函数。(使用时应包含头文件“alloc.h”或“malloc.h”或“stdlib.h”)
1.malloc函数
函数原型为void
*malloc(unsigned
int
size);在内存的动态存储区中分配一块长度为"size"
字节的连续区域。函数的返回值为该区域的首地址。
“类型说明符”表示把该区域用于何种数据类型。(类型说明符*)表示把返回值强制转换为该类型指针。“size”是一个无符号数。例如:
pc=(char
*)
malloc
(100);
表示分配100个字节的内存空间,并强制转换为字符数组类型,函数的返回值为指向该字符数组的指针,
把该指针赋予指针变量pc。若size超出可用空间,则返回空指针值NULL。
2.calloc
函数
函数原型为void
*calloc(unsigned
int
num,
unsigned
int
size)
按所给数据个数和每个数据所占字节数开辟存储空间。其中num为数据个数,size为每个数据所占字节数,故开辟的总字节数为
num*size。函数返回该存储区的起始地址。calloc函数与malloc
函数的区别仅在于一次可以分配n块区域。例如:
ps=(struct
stu*)
calloc(2,sizeof
(struct
stu));
其中的sizeof(struct
stu)是求stu的结构长度。因此该语句的意思是:按stu的长度分配2块连续区域,强制转换为stu类型,并把其首地址赋予指针变量ps。
3.
realloc函数:
函数原型为void
*realloc(void
*ptr,
unsigned
int
size)
重新定义所开辟内存空间的大小。其中ptr所指的内存空间是用前述函数已开辟的,size为新的空间大小,其值可比原来大或小。函数返回新存储区的起始地
址(该地址可能与以前的地址不同)。例如p1=(float
*)realloc(p1,16);将原先开辟的8个字节调整为16个字节。
**动态申请的内存空间要进行手动用free()函数释放
⑽ c语言中什么是动态分配内存
就是当你的程序中使用数组或者是指针变量的时候,为了能够合理地利用内存空间来进行程序运行,自动开辟内存在栈区,最后用完这些内存再将其回收的方式。动态内存分配不像静态内存分配方法那样需要预先分配存储空间,而是由系统根据程序的需要来分配,分配大小就是程序要求大小。
一般在C语言中使用malloc和free方法
头文件为malloc.h或者是stdlib.h,