一. 内存分配
内存会分为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”作为字符数组初始化的时候就不是一个常量,其他情况下是一个常量。