学习笔记4(内存申请 释放, 字符串)

一. 内存分配

内存会分为3个区:

1.程序区

程序去: 存放的是二进制的文件

2.静态存储区

静态存储区: 全局变量和静态变量

3.动态存储区

动态存储区: 又分为 堆区和栈区
堆区:用于程序动态分配
栈区:编译器自动分配,编译器自动申请和释放 2M

二. 内存的申请

malloc 函数: (用 malloc 申请的内存一定要做个if(xxx == NULL) 的判断,防止空指针)

 void* malloc(size_t size)
 分配内存的单元是 字节, 大小 size,连续的内存
 如果申请失败,返回值是NULL

calloc 函数

void* calloc(size_t _Count,size_t _Size)
 申请 _Count 个 大小为_Size 的连续空间,这个连续空间的大小是_Size,
 而不是  _Count * size, 同时,它会初始化为0,如果申请失败,返回值是NULL

三. 内存的释放

动态申请的内存一定要收到释放

 free(*p) 函数,释放内存
 原则:
  1.不能重复释放()
  2.必须赋值NULL
  3.申请和释放一一对应

如果申请和释放不一 一对应,会照成内存泄露

四. C/C++里面的字符串

c里面表示字符串有两种方式:

方式1:
char ch1[10] = { 'c', 'h', 'i' , 'n', 'a', '\0' , 'a'};
printf(" %s \n" ,   ch1) //打印结果为 china 
系统会取到第一'\0' 为结束
char ch1[20] = "china";
ch1[0] = 's' ;
printf(" %s \n", ch1) //打印结果是 shina

//ch1 是一个常量,不能被修改
//但是ch1[0] = 's',是修改ch1所指向的地址上面的值为 's'
方式2:
char * ch = "china";
ch[0] = 's'; //这里会报错

把一个字符串“china”赋值给一个字符指针变量时如:char* ptr = “china”;因为定义的是一个普通字符指针,
并没有定义空间来存放“china”,所以编译器得帮我们先找个地方存放“abc”,
显然,这里的“china”会被当成常量并把它放到程序的常量区是编译器最合适的选择。
所以修改 char* ptr = “china” 中的值,
如:ptr[0] = “g”的时候,会报错,
因为这个地址里面存的是常量,常量是不能修改的。
Char *str = “hello are you”;
因为  “hello are you” 出现在一个表达式中时,“hello are you”使用的值就是这些字符所存储的地址(在常量区)。所以这个地址可以赋值给一个 char 类型的指针变量注意:“hello are you”作为字符数组初始化的时候就不是一个常量,其他情况下是一个常量。 

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容