当前课程知识点:C++语言程序设计基础 > 第6章 数组、指针与字符串(二) > 指针与数组 > 用指针访问数组元素
数组是一组连续存储的同类型数据,可以通过指针的算术运算,使指针依次指向数组的各个元素,进而可以遍历数组。
定义指向数组元素的指针
定义与赋值
例:int a[10], *pa;
pa=&a[0]; 或 pa=a;
等效的形式
经过上述定义及赋值后
*pa就是a[0],*(pa+1)就是a[1],... ,*(pa+i)就是a[i]. a[i], *(pa+i), *(a+i), pa[i]都是等效的。
注意
不能写 a++,因为a是数组首地址、是常量。
例6-7
设有一个int型数组a,有10个元素。用三种方法输出各元素:
使用数组名和下标
使用数组名和指针运算
使用指针变量
例6-7 (1) 使用数组名和下标访问数组元素
#include using namespace std; int main() { int a[10] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 0 }; for (int i = 0; i < 10; i++) cout << a[i] << " "; cout << endl; return 0; }
例6-7 (2) 使用数组名和指针运算访问数组元素
#include using namespace std; int main() { int a[10] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 0 }; for (int i = 0; i < 10; i++) cout << *(a+i) << " "; cout << endl; return 0; }
例6-7 (3) 使用指针变量访问数组元素
#include using namespace std; int main() { int a[10] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 0 }; for (int *p = a; p < (a + 10); p++) cout << *p << " "; cout << endl; return 0; }
大家好
欢迎回来继续学习
C++语言程序设计
这一节我们学习
如何用指针去处理数组元素
我们知道数组呢
是一组连续存放的
同类型数据的这么一个集合
因此呢
我们就可以用指针
去指向数组元素
然后通过指针的算术运算
依次遍历数组的各个元素
首先我们来看
如何定义指向数组的指针
首先我们来看
如何定义指向数组元素的指针
我们来看这个例子
在这儿定义了一个数组a
它具有10个元素
同时定义了一个
指向int类型的指针pa
像这样定义之后呢
我们就可以将数组
a的它的首元素的地址取出来
计算出来 赋值给pa
也就是a[0]的地址
大家看这里用了地址运算
我们将a[0]的地址赋给pa
这样pa就指向了
数组的最开始位置
或者我们用另外一种格式呢
也是效果一样的
就是将数组a的这个数组名
就是a赋值给pa
因为数组名也是数组的首地址
好 经过这样的定义和赋值以后
我们看看很多写法
它们之间就等效了
那么*pa就是a[0]
pa+1进行指针运算呢
实际就相当于a[1]
因为pa+1指向的就是a[1]
pa+i经过指针运算
就相当于是a[i]
所以这样四种写法
就都是等效的
我们通过数组名下标
去访问一个元素
或者通过pa+i进行指针运算
去访问一个元素
还或者呢
我们可以将a
就当成一个地址类型的数据
它本身就是地址常量
我们用a+i再进行指针运算
效果也是一样的
那么其实呢
很常用的一个形式就是
当pa得到了a的首地址
指向了数组a以后
就拿pa本身当数组名用
用pa方括号下标
跟a方括号下标
它效果是一样的
虽然这四种形式都是等效的
它效果都是一样的
但是我们写程序的时候
一般不会说拿数组名a
去当地址用
去做地址运算
那样是不常用的写法
还要注意
我们可以用指针的自增运算
比如说pa++
去使它指向下一个
再下一个 再下一个元素
但是我们可千万不能写a++
因为a是数组的首地址
是常量
它是不能自增的
它的值不是能改变的
下面我们来看一个例子
在这个例题中呢
我们用三种不同的办法
来遍历一个数组
所谓遍历
就是把数组的各个元素
从头到尾依次过一遍
经历一遍
这个遍历可以是简单地输出
这个数组元素
当然也可能会有复杂的计算
我们这道例题的遍历比较简单
那这道例题
要演示的是哪三种方法呢
一个就是我们最常规的
用数组名和下标的方式
依次访问数组的各个元素
用循环
第二种方式呢
我们尝试用数组名
和指针运算的方式
来访问数组的各个元素
虽然我们讲了这种方式
但是一般我们不会这样写程序
只是在这里给大家对比 演示一下
那么第三种方式呢
也是很常用的方式
就是通过指针去访问
数组的各个元素
看这第一个程序呢
就使用我们最熟悉的
数组名下标的方式
去遍历整个数组元素
定义好了一个
具有10个元素的数组a
也初始化好了
然后就用for循环
去遍历这个数组
也就是把数组所有的元素
都经历一遍
实际上输出一遍
这是最常规的方法
大家会觉得这个方法挺好的
够用了
那接下来呢
看看第二个办法
好好的数组名不当数组名用了
拿它当个什么 地址
其实它确实就是数组的首地址
那么访问元素a[i]的时候呢
就是a+i
a是起始地址 再加上i
我们注意
这个跟指针运算一样的
它是地址类型的数据
是首地址
它加i
绝对不是它里面存放的那个地址
绝对值加i
它是从当前位置开始
往后移
往后移动
或者指向它后面的第i个元素
好 指向那儿了以后
作*运算 就是指针运算
那不还是a下标i吗
就是下标为i的那个元素
这是等效的
再看呢
这也是等效的表现形式
定义一个指针p
用a去初始化p
然后用p
作为指向每一个元素的指针
依次往后走
大家看
循环每做完一次 p+1
加1就是指向下一个元素
再加1又指向下一个元素
自己自增
自增就是指向下一个元素
所以每一轮都输出一个
由指针P所指向的元素
*P 指针运算
这一共多少轮呢
它控制的循环次数
由p要小于a+10来控制
也就是数组不能越界呀
所以这三种表现方式
都是等效的
当然如果你有数组名的话
首选用数组名的形式
那个最简洁方便
可读性也好
-导学
--第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章小结
--第六章小结
-综合实例
--综合实例
-实验六(下)
--实验六(下)