#include<stdio.h>
#include<malloc.h>
int main()
{
//静态数组
int a[5] = {4,10,2,8,6};
//动态数组(动态内存分配)
int len;
printf("请输入你需要分配的数组的长度:len = ");
scanf("%d",&len);
int * pArr = (int *)malloc(sizeof(int)*len);
//上面的操作造成的结果是分配了20个字节,逻辑上的结果为指针指向前四个字节,pArr+1指向随后四个字节,依次。
//可以将pArr作为该动态数组的数组名,len可根据用户的需求改变,分配的地址可释放
//关于(int *) 因为malloc返回的只是第一个字节的地址,不能表明为何类型地址(该地址又称为干地址)
//所以对其进行强制转换,将地址转换成对应类型的指针(指针的本质也是地址),即转换后的地址能表明类型
//*pArr = 4;//类似于a[0]=4;
//pArr[1]=10;//类似于a[1]=10;
//可以把pArr当成普通数组来使用
for(int i=0;i<len;i++)
scanf("%d",pArr+i);
for(i=0;i<len;i++)
printf("%d\n",*(pArr+i));
//释放动态空间
free(pArr);//把pArr所代表的动态分配的20个字节的内存释放
return 0;
}
郝斌--数据结构--动态分配基础复习
最新推荐文章于 2024-04-27 22:24:35 发布