一.内存划分:(地址由高到低)
1.栈区
栈区的数据以栈的形式进行存储,特点:先进后出
函数体内存放的局部变量存放在栈区,由系统分配空间和系统释放.
开发人员不需要关心如何为局部变量分配空间.
int a = 10;
printf(“%p\n”,&a);
2.堆区由开发人员手动申请,手动释放,唯一一块由开发人员操作的区域.
1⃣申请内存的函数
void *malloc(size_t);
返回类型为:void *,泛型类,可以转化为其他类型.
malloc 为函数名, size_t 为参数, unsigned long 类型的参数,也就是传入的字节数
在堆区里申请4个字节的空间,返回的是申请空间的首地址.
int *p = malloc(4);
申请了4个连续字节,放100;
*p = 100;
printf(“%p\n”,p);
printf(“%d\n”,*P);
在堆中”iPhone”,多出一个字节,存放’\0’,为了安全
char *p1=malloc(7);
strcpy(p1,”iPhone");
// 将第三个字母改为’\0'
*(p1+2) =‘\0’;
strcpy((p1+2),”abcd");
printf(“%s\n”,p1);