一 、静态申请:
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 { ar[i] = i+1; } for(int i=0; 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 { ar[i] = i+1; } for(int i=0; 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 { ar[i] = i+1; } for(int i=0; i { printf("%d ", ar[i]); } printf("\n"); n = 5; int *new_tmp = (int*)realloc(ar, sizeof(int)*n); for(int i=0; i { printf("%d ", ar[i]); } printf("\n"); free(new_tmp); } 参考文章
发表评论