文章目录
- 前言
- 一、内存的编址与寻址
- 1·1 内存单元大小
- 1·2 内存的编址方法
- 1·3 内存与数据类型的关系
- 1·4 内存对齐
- 1·5 从内存编址角度看数组
- 1·6 C语言如何操作内存
- 二、内存管理
- 2·1 栈
- 2·2 堆
前言
这是一篇关于C语言内存的博客,哈哈哈我觉得我最近由于收到offer后有点懈怠了。希望自己还是一个勤勉的自己~~
还是好好学习好好写博客吧。
不积跬步无以至千里。
一、内存的编址与寻址
1·1 内存单元大小
内存大小有4个:位,字节,半字,字。
位和字节是用的最多的。
1·2 内存的编址方法
内存在逻辑上可以想成一个一个挨着的格子,这些格子就是存放数据,每个格子都有一个专属编号,这个编号就是内存地址。
内存地址与内存空间一一对应并且永久绑定,这就是内存编址的方法。在程序运行的时候,CPU只认识内存地址,不在乎格子(格子就是内存地址)到底在哪里。
注意::内存的编址是以字节为单位的!!!
所以一个格子就表示一个字节!!!
1·3 内存与数据类型的关系
C语言的基本数据类型:char int short long float double
int类型就与CPU的位数有关,32位系统int类型是4字节;64位系统int类型是8字节。
char 类型就是1字节,
还有bool类型,是一个比特位。
在32位环境下,我们实际定义的bool类型变量,编译器会帮我分配一个字节来存储bool变量,编译器怎么做虽然浪费了31位的内存,但是提高了效率。
1·4 内存对齐
内存的对齐访问不是逻辑问题,而是硬件问题。所以基于硬件角度考虑,对齐访问的效率就大大提高。
1·5 从内存编址角度看数组
1·6 C语言如何操作内存
C语言中数据类型的本质含义:表示分配内存格子的长度和解析方法。
二、内存管理
2·1 栈
一个例子:
2·2 堆
还有复杂的数据结构:比如链表,哈希表,图,但是我一般没有用到哈希表和图。而且嵌入式这块这两个也几乎用不到。所以我就不过多介绍啦~~