在上一篇文章中,我们介绍了函数可以作为独立的黑盒处理数据,但这带来了一个棘手的物理限制:当我们把变量传递给函数时,系统默认执行的是"按值传递(Pass by Value)"。这意味着,如果传递的是一个体积巨大的数组,系统要在极短时间内完成全量的物理数据拷贝,不仅效率极低,更极其容易突破栈内存的容量上限,导致程序崩溃(栈溢出)。
为了不复制庞大的数据原件,又能让处于隔离状态的函数内部精准访问目标数据,计算机科学引入了一种更为底层的解决方案------传递数据所在的位置编码。这便是 C/C++ 语言中最核心的底层机制:地址(Address)与指针(Pointer)。
本系列文章往期回顾:
第二部分 【C++的奇妙之旅】
- 【信奥业余科普】C++ 的奇妙之旅 | 09:信奥赛场的核心语言------C++ 的前世今生
- 【信奥业余科普】C++ 的奇妙之旅 | 10:代码是如何运行的?------编译过程与"Hello, World"
- 【信奥业余科普】C++ 的奇妙之旅 | 11:程序的处理核心------变量与常用数据类型
- 【信奥业余科普】C++ 的奇妙之旅 | 12:程序的交互与加工------数据的输入与算术运算
- 【信奥业余科普】C++ 的奇妙之旅 | 13:为什么 0.1+0.2≠0.3?------解密"爆int"溢出与浮点数精度的底层原理
- 【信奥业余科普】C++ 的奇妙之旅 | 14:程序的分叉路口------逻辑判断与 if-else 语句
- 【信奥业余科普】C++ 的奇妙之旅 | 15:让机器不知疲倦的秘密------循环语句背后的底层逻辑
- 【信奥业余科普】C++ 的奇妙之旅 | 16:批量处理数据的基石------数组的设计哲学
- 【信奥业余科普】C++ 的奇妙之旅 | 17:面的铺展与文本的本质------二维数组与字符串
- 【信奥业余科普】C++ 的奇妙之旅 | 18:代码的积木与黑盒------函数的底层逻辑与基础语法
一、 内存模型与地址的物理原理
在理解指针之前,我们需要先看清计算机内存的真实面貌。
科学
在硬件层面,内存条可以被视作一条极其漫长的连续存储空间,这条空间被精准分割成了数亿个大小完全相同的隔间(这就是我们常说的"字节 Byte")。为了能准确找到每一块隔间,操作系统在开机运作时,会为它们按顺序编上固定且独一无二的编号(例如 0x0001, 0x0002 一直到几十亿)。这些物理编号,就是数据的内存地址(Memory Address)。
全文详见:https://www.coderli.com/cs-basics-19-cpp-pointers/
https://www.coderli.com/cs-basics-19-cpp-pointers/
https://www.coderli.com/cs-basics-19-cpp-pointers/