一 、静态申请:
int a=10;//在栈区开辟空间,不需要考虑释放
int ar[10]={1,2,3,4,5,6};
1. 空间开辟大小是固定的。
2. 数组在申明的时候,必须指定数组的长度,它所需要的内存在编译时分配。 但是对于空间的需求,不仅仅是上述的情况。有时候我们需要的空间大小在程序运行的时候才能知道,那数组的编 译时开辟空间的方式就不能满足了。 这时候就只能试试动态存开辟了。
二、动态申请
自己申请,自己释放。
三、动态申请内存函数
- Malloc函数原型 void *malloc( size_t size );
向操作系统申请空间我们要注意三个问题
- 申请空间的大小自己决定。sizeof (int/double/cher/float) *n;
- 要进行强转。int ar*=(int*)malloc(Sizeof(int/double/cher/float) *n)
- 看是否申请空间成功,成功就可以正常使用。
void main()
{
int n;
printf("input n:>");
scanf("%d", &n);
int *ar = (int *)malloc(sizeof(int) * n);
if(ar == NULL)
{
printf("malloc faild.\n");
return;
}
printf("malloc success.\n");
for(int i=0; i<n; ++i)
{
ar[i] = i+1;
}
for(int i=0; i<n; ++i)
{
printf("%d ", ar[i]);
}
printf("\n");
free(ar);
}
2、calloc申请一个空间并且会初始化为0。
函数原型 void *calloc( size_t num, size_t size );
- 申请空间的大小自己决定。
- 要进行强转。int ar*=(int*)calloc(n,sizeof(int/double/cher/float) )
- 看是否申请空间成功,成功就可以正常使用。
void main()
{
int n;
printf("input n:>");
scanf("%d", &n);
int *ar = (int *)calloc(n, sizeof(int));
if(ar == NULL)
{
printf("calloc faild.\n");
return;
}
printf("calloc success.\n");
for(int i=0; i<n; ++i)
{
ar[i] = i+1;
}
for(int i=0; i<n; ++i)
{
printf("%d ", ar[i]);
}
printf("\n");
free(ar);
}
3、realloc函数的出现让动态内存管理更加灵活。
有时会我们发现过去申请的空间太小了,有时候我们又会觉得申请的空间过大了,那为了合理的时候内存, 我们一定会对内存的大小做灵活的调整。那 realloc 函数就可以做到对动态开辟内存大小的调整。
realloc函数原型:void *realloc( void *memblock, size_t size );
memblock 是要调整的内存地址 size 调整之后新大小 返回值为调整之后的内存起始位置。 这个函数调整原内存空间大小的基础上,还会将原来内存中的数据移动到新的空间。
void main()
{
int n = 10;
int *ar = (int *)malloc(sizeof(int)*n);
assert(ar != NULL);
for(int i=0; i<n; ++i)
{
ar[i] = i+1;
}
for(int i=0; i<n; ++i)
{
printf("%d ", ar[i]);
}
printf("\n");
n = 5;
int *new_tmp = (int*)realloc(ar, sizeof(int)*n);
for(int i=0; i<n; ++i)
{
printf("%d ", ar[i]);
}
printf("\n");
free(new_tmp);
}