当前课程知识点:C++语言程序设计基础 > 第6章 数组、指针与字符串(一) > 指针的定义和运算 > 指针的算术运算、关系运算
指针的算术运算、关系运算
指针与整数的加减运算
指针++,--运算
指针p加上或减去n
其意义是指针当前指向位置的前方或后方第n个数据的起始位置。
指针的++、--运算
意义是指向下一个或前一个完整数据的起始。
运算的结果值取决于指针指向的数据类型,总是指向一个完整数据的起始位置。
当指针指向连续存储的同类型数据时,指针与整数的加减运和自增自减算才有意义。
指向相同类型数据的指针之间可以进行各种关系运算。
指向不同数据类型的指针,以及指针与一般整数变量之间的关系运算是无意义的。
指针可以和零之间进行等于或不等于的关系运算。
例如:p==0或p!=0
大家好
欢迎回来继续学习
C++语言程序设计
这一节我们来学习
指针的运算
指针呢
它除了可以进行
我们前面学过的这种*
这种指针运算以外
它还可以进行算术运算
和关系运算
指针的算术运算呢
包括指针与整数的加减运算
还有呢
指针自增1 自减1这样的运算
那么指针类型的变量
它的算术运算
跟我们普通的其他
比如说整数 浮点数
这些算术运算有很大的不同
虽然看起来
也是在做加减
比如说
让指针加上或减去n
绝对不是说
让指针里面存放的这个地址
真的加了n个字节
减了n个字节
不是的
它的含义是
让指针
指向当前位置的前方
或者后方
第n个数据的起始位置
我们想想为什么是这样呢
因为指针必须要总是指向
一个完整数据的起始位置
比如说一个int数据占四个字节
它当然应该指向它的首字节
这样的话每次取数据的时候
或者存数据的时候
我们从首字节开始
连续处理四个字节
如果我们让一个指针
指向了一个int数据的中间位置
两个字节的地方
那么它就没有任何意义了
它取出来的数
就完全是失真的了
所以对于指针运算来说
它的运算规则
就保证了这一点
加上n
它向前走n个完整数据的位置
像指针的自增1 自减1运算
也是一样
它表示指向下一个
或者前一个完整数据的起始位置
所以说
指针与整数进行加法减法运算
它的自增自减运算的结果
使得它的地址值
到底变化成了几呢
这个取决于它指向的数据类型
比如说它要指向一个short类型
它加1可能就是加了两个字节
还有呢
这种指针跟整数的加减运算
或者它自增自减运算
一般不用于
指向单独变量的指针
如果这一个指针
它就指向一个单独的int
double变量
那么你加1以后
它就指向这个变量之后的
下一个内存单元了
那个内存单元里面存的是什么
完全不确定的呀
那就没有任何意义
所以一般是当指针指向
连续存储的同类型数据的时候
指针与整数的加减运算
还有自增自减运算才有意义
我们看一下这个图
来理解一下
指针与整数相加的含义
比如说我们定义了一个
short类型的数组a
具有4个元素
每个元素呢
因为是short类型
所以它占两个字节
然后又再定义一个指针pa
我们知道a是数组的首地址
数组名就是数组的首地址
所以我们用这个地址
去初始化pa
a是首地址
就是首个元素的地址
首个元素是什么类型呢
是一个short类型的元素
所以它就是short类型的地址
正好这里的pa
也是指向short的指针
用于存放short类型变量地址的
那这个时候
用a去初始化pa
现在呢
经过这样初始化以后
如果用pa去进行指针运算
那么寻址寻到的是什么
就是元素a[0]
是一样的
pa+1呢
它在它原来指向的位置的
这个地方 加2
本来pa在这个地方的
加了2走了两个字节
到这个地方来了
对它进行指针运算
相当于
指定现在要访问a1
再加1
就是p2+2
那么又进两个字节
pa+3又进两个字节
所以通过这个我们就看到
指针与整数进行运算
并不是加1
它的地址值就增加一个字节的
加1意味着什么
要看它所指向的对象类型是什么
指向还可以进行关系运算
指向同一个类型对象的指针之间
是可以进行关系运算的
但是
指向不同类型对象的指针之间
以及指针
与普通的整数类型的
数据之间的关系运算
它就是没有意义的
但是有一个整数例外
就是0
指针可以跟0去比较
进行关系运算
看它等于还是不等于0
表示判断这个指针是否空指针
-导学
--第1章导学
-计算机系统简介
--计算机系统简介
--计算机系统简介 测试题
-计算机语言和程序设计方法的发展
--计算机语言和程序设计方法的发展 测试题
-面向对象的基本概念
--面向对象的基本概念 测试题
-程序的开发过程
--程序的开发过程
--程序的开发过程 测试题
-信息的表示和储存
--计算机的数字系统
--数据的编码表示
--信息的表示和储存 测试题
-实验指导
-导学
--第二章导学
-C++语言概述
--C++语言概述 测试题
-基本数据类型、常量、变量
--程序举例
--基本数据类型、常量、变量 测试题
-运算与表达式
--运算与表达式 测试题
-实验二:简单程序设计(上)
-数据的输入和输出
--数据的输入和输出
--数据的输入和输出 测试题
-选择结构
--if语句
--switch语句
--选择结构 测试题
-循环结构
--for语句
--循环结构 测试题
-自定义类型
--自定义类型
--自定义类型
-第2章小结
--第二章小结
-实验二:C++简单程序设计(下)
-导学
--导学
-函数定义
--函数定义
--函数定义 测试题
-函数调用
--例3-2
--例3-3
--例3-4
--例3-5
--例3-6
--函数调用 测试题
-嵌套与递归
--例3-9
--例3-10
--嵌套与递归 测试题
-函数的参数传递
--函数的参数传递
--函数的参数传递 测试题
-引用类型
--引用类型 测试题
-含有可变参数的函数
--含有可变参数的函数 测试题
-内联函数
--内联函数 测试题
-constexpr函数
--CONSTEXPR函数课后习题
-带默认参数值的函数
--带默认参数值的函数 测试题
-函数重载
--函数重载 测试题
-C++系统函数
--C++系统函数习题
-第3章小结
--第三章小结
-实验三(上)函数的应用
-实验三(下)函数的应用
-导学
--导学
-面向对象程序的基本特点
--面向对象程序的基本特点 测试题
-类和对象
--类和对象的定义
--类和对象 测试题
-构造函数
--构造函数基本概念
--委托构造函数
--复制构造函数
--构造函数 测试题
-析构函数
--析构函数
--析构函数 测试题
-类的组合
--类的组合
--类的组合程序举例
--前向引用声明
--类的组合 测试题
-UML简介
--UML简介
--UML简介课后习题
-结构体与联合体
--结构体与联合体 测试题
-枚举类
--枚举类
--枚举类 测试题
-第4章小结
--第四章小结
-实验四(上)
--实验四(上)
-实验四(下)
--实验四(下)
-导学
--导学
-标识符的作用域与可见性
--标识符的作用域与可见性 测试题
-对象的生存期
--对象的生存期
--对象的生存期 测试题
-类的静态成员
--类的静态成员 测试题
-类的友元
--类的友元 测试题
-共享数据的保护
--共享数据的保护 测试题
-多文件结构和预编译命令
--多文件结构和预编译命令 测试题
-第5章小结
--小结
-实验五
--实验五
-导学
--导学
-数组的定义与初始化
--数组的定义与使用
--一维数组应用举例
--数组的定义与初始化 测试题
-数组作为函数的参数
--数组作为函数的参数 测试题
-对象数组
--对象数组
--对象数组 测试题
-基于范围的for循环
-指针的定义和运算
--指针的定义和运算 测试题
-综合实例
--综合实例
-实验六(上)
--实验六上
-指针与数组
--指针数组
--指针与数组 测试题
-指针与函数
--指针类型的函数
--指向函数的指针
--指针与函数 测试题
-对象指针
--对象指针
--对象指针 测试题
-动态内存分配
--动态内存分配 测试题
-智能指针
--智能指针
-vector对象
--vector对象
--vector对象 测试题
-对象复制与移动
--移动构造
--对象复制与移动 测试题
-字符串
--C风格字符串
--string类
--字符串 测试题
-第6章小结
--第六章小结
-综合实例
--综合实例
-实验六(下)
--实验六(下)