一 、静态申请:

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);

}

参考文章

评论可见,请评论后查看内容,谢谢!!!评论后请刷新页面。