当前课程知识点:程序设计基础 > 第二章 变量与代数思维 > 2.6 关于变量的讨论 > 2.6.5 指针的 读/写 操作
下面我们看下一个 第五个我们讨论的
那么 对变量地址它所对应的单元
也就是我拿到了一个地址值
我想对那个单元进行读写操作
读它单元的值 或者往它里头写东西
该怎么做 看这段代码
前面有一些代码我把它省略掉了
我们关注的是新增加的这部分
我们看到呢 有几个新的 *PN=999
*PF=888 这几行代码
那么 这个操作 大家又看到*了
不过呢 这个时候的* 它表示的是
去获得这个指针变量PN 或者指针变量PF
指针变量PD 指针变量PC的那个单元
你可以把它看成一个新的变量名
等号999 888 777 表示把后面这四个值
送到左面这个单元里面去
所以*PN的含义就是把999送到PN
这个单元的值 注意这个值是个地址值
这个值所对应的单元
就是这个地址值所标识的单元
另外一个 送到那个单元里去
我们下面画了一个示意图
你可以看到 把999是送到了
0X22FF44这个单元里去了
这个单元就是N那个单元
因为22FF44是N这个变量的地址
而PN这个变量呢 PN这个变量
它的地址单元是在22FF30这个位置
而它的内容呢 就是22FF44
正好就是N那个单元的地址值
所以*PN=999 就是让计算机去取出PN的值
22FF44 用这个值去找到一个单元
其实就是N的那个单元 把999放进去
这就是*指针变量等于一个值它的含义
这是对它进行一个写的操作
读的操作 把内容读出来 一样
我们用cout写了四个cout的语句
*PN这个时候它的含义 这个*的含义又有点差别
它表示把指针变量包含的那个地址值
所对应的单元里头的值取出来
具体来讲 *PN就是把PN这变量里头存的地址值
按照这个地址找到这个单元
其实就是N所在的单元
把那个N里头的值拿出来
所以第一条输出语句 cout *PN
是把N的结果输出出来了
不是把PN的结果输出出来
如果要输出PN的结果的话 那个*就不能要
这是我们以前代码 大家可以对照一下
是不一样的 这里头多了个*
它表示要把变量的值给它取出来
这是这个指针变量它所指的单元的值的一个读写
下面这个是前面我们代码的输出结果
我们可以看到 就像我们分析的那样子
*PN的确是把N的值输出出来了
而*PN=999也的确是把N的值改变了
那么这么看起来 我们可以画一个示意图
一般来讲 为了表达PN跟N这个变量的关系
我们通常是用这样的一种形式
用PN去指向一个方框
然后这个方框里头是999
表示的是一个N这个变量的值
那么所以 顾名思义
我们为什么把类型名后面跟上一个*称为指针
就是因为你对这样的变量进行访问的时候
它其实会根据你所指的这个单元的值
所指的单元的这个地址值
去对另外一个单元进行操作
看上去像一个指针一样
所以这个是一个指针这个类型
它跟原始的这个数据类型中间的一种关系
这里头我们可以看一个简单的动画
表示它的变化的一个过程
我们可以看到PN它的值
就是N的地址值
所以我画一个箭头指向N
然后下面这个单元 这个变量
其实也是类似的
你可以用多个指针变量来指向同一个内存单元
就像这个图上大家看到的
那么 当然了 我们也可以把好多个
不同的内存单元通过类似这种方法
把它串起来 像这样的一个图
我们可以看到 最开始的时候是2ED22C
那么它指向了下面这个单元
其他的类似 它指向第三个
这个指向第四个
我们可以看另外的一个例子
比方像现在这个地方 在左边
我们可以看到 有一个变量
它存放在213D44这个位置
那么里头的值呢 是0X22FF44
按照我们前面讲的 这个单元
实际上是指向这个位置的
然后奇怪的是这个单元的值
它是0X22FF47是另外一个单元的地址
那么以此类推
每一个单元其实是另外一个单元的地址
这样的话我们可以看到
这些单元之间实际上是串接到一起的
而每一个单元下面跟着一些数
3.1425 960.123 100 0 还有一个999
这些值 看上去就像一条链条一样
我们把这样的一个称作是组织成了一个链表的形式
关于链表的生成过程
我们还会在后头的章节里头对它进行介绍
-1.1 基础知识
-1.2 买菜问题
-1.3 数学运算
-1.4 补充说明
-1.5 总结
--1.5 总结
-程设论道
--程设论道
-师生问答
-第一章 编程初步--语法自测
-2.1 关于超级计算器的几点思考
-2.2 电子秤模拟 — 背景介绍及需求分析
-2.3 电子秤模拟 — 代码实现
-2.4 变量定义与变量类型
-2.5 猜数游戏与数据表示
-2.6 关于变量的讨论
--公告
-2.7 变量体现的计算思维
-程设论道
--程设论道
-师生问答
--师生问答
-第二章 变量与代数思维--语法自测
-3.1 谁做的好事——语义表示
-3.2 谁做的好事——真假检查
-3.3 谁做的好事——循环枚举
-3.4 谁是嫌疑犯——多重循环枚举
-3.5 谁是嫌疑犯——破案线索表示
-3.6 谁是嫌疑犯——用二进制枚举
-程设论道
--程设论道一
--程设论道二
--程设论道三
-师生问答
-第三章 逻辑推理与枚举解题--语法自测
-4.1 插花游戏
-4.2 筛法
-4.3 线性查找
-4.4 折半查找
--4.4.1 提问
-4.5 排序问题
-4.6 总结
--4.6.1 总结
-程设论道
--程设论道二:筛法
-师生问答
-第四章 筛法与查找--语法自测
-5.1 阶乘
-5.2 排序
-5.3 矩阵填充
-5.4 分书与八皇后
-5.5 青蛙过河
-程设论道
--程设论道一
--程设论道二
-师生问答
--师生问答一
--师生问答二
-第五章 分治思想与递归--语法自测
-6.1 兔子数列问题
-6.2 分鱼问题
-6.3 橱窗的插花问题
-6.4 最长公共子序列问题
-程设论道
--程设论道一
--程设论道二
-师生问答
--师生问答
-第六章 递推与动态规划--语法自测
-7.1 统计记录总数
-7.2 统计活跃用户数
-7.3 统计在线时长
--7.3.2 结构
-7.4 总结
--7.4.1 总结
-程设论道
--程设论道
-师生问答
--师生问答
-第七章 文本数据处理--语法自测
-8.1 将数据组织成链表
-8.2 提高链表访问效率 —— 哈希链表
-8.3 以二进制文件存储链表
-程设论道
--程设论道一
--程设论道二
-师生问答
--师生问答
-第八章 非文本数据处理--语法自测
-9.1 自动售卖程序
-9.2 配制水果信息
-9.3 指定界面语言
-程设论道
--程设论道
-师生问答
--师生问答
-第九章 可配置的程序设计--语法自测