第六节--指针专题一

一、指针基本用法

掌握指针的基本用法


指 针:
C程序设计中使用指针可以

使程序简洁、紧凑、高效、
有效地表示复杂的数据结构
动态分配内存
得到多于一个的函数返回值


地址和变量:
第六节--指针专题一
第六节--指针专题一


指针变量的说明:

一般形式如下: <存储类型> <数据类型> * <指针变量名> ;

例如,char *pName ;
指针的存储类型是指针变量本身的存储类型。
指针说明时指定的数据类型不是指针变量本身的数据类型,而是指针目标的数据类型。简称为指针的数据类型


指针在说明的同时, 也可以被赋予初值,称为指针的初始化
一般形式是:
<存储类型> <数据类型> *<指针变量名> = <地址量> ;
例如:int a, *pa=&a;
在上面语句中,把变量a的地址作为初值赋予了刚说明的int型指针pa。
int a = 3; //int a; a = 3;
int *pa = &a; //int * pa; pa = &a;
例如:
第六节--指针专题一


指针指向的内存区域中的数据称为指针的目标
如果它指向的区域是程序中的一个变量的内存空间, 则这个变量称为指针的目标变量。 简称为指针的目标。
第六节--指针专题一


引入指针要注意程序中的px、*px 和 &px 三种表示方法的不同意义。设px为一个指针,则:
px — 指针变量, 它的内容是地址量
*px — 指针所指向的对象, 它的内容是数据
&px — 指针变量占用的存储区域的地址,是个常量

第六节--指针专题一


指针的赋值运算指的是通过赋值运算符向指针变量送一个地址值
向一个指针变量赋值时,送的值必须是地址常量或指针变量,不能是普通的整数(除了赋零以外)

指针赋值运算常见的有以下几种形式:
把一个普通变量的地址赋给一个具有相同数据类型的指针
double x=15, *px;
px=&x;
把一个已有地址值的指针变量赋给具有相同数据类型的另一个指针变量.例如:
float a, *px, *py;
px = &a;
py = px;
把一个数组的地址赋给具有相同数据类型的指针。例如:
int a[20], *pa;
pa = a; //等价 pa = &a[0]


思考
什么叫指针?
指针占几个字节?—4个字节


二、指针运算

指针的算术运算见下表:
第六节--指针专题一


指针加减一个n的运算:px + n px - n
第六节--指针专题一
注意

不同数据类型的两个指针实行加减整数运算是无意义的
px+n表示的实际位置的地址量是:
(px) + sizeof(px的类型) * n
px-n表示的实际位置的地址量是:
(px) - sizeof(px的类型) * n


两指针相减运算
px-py 运算的结果是两指针指向的地址位置之间相隔数据的个数因.此,两指针相减不是两指针持有的地址值相减的结果。
两指针相减的结果值不是地址量,而是一个整数值,表示两指针之间相隔数据的个数。


指针加一、减一运算
px++, ++px, px–, --px

第六节--指针专题一


指针的关系运算符
第六节--指针专题一指针关系运算
两指针之间的关系运算表示它们指向的地址位置之间的关系。指向地址大的指针大于指向地址小的指针。
指针与一般整数变量之间的关系运算没有意义。但可以和零进行等于或不等于的关系运算,判断指针是否为空。
第六节--指针专题一
第六节--指针专题一


总结与思考
主要介绍指针的各种运算,包括算术元素和关系运算
思考
指针运算的本质是什么?
指针加1,移动多少字节?


三、指针与数组

在C语言中,数组的指针是指数组在内存中的起始地址,数组元素的地址是指数组元素在内存中的起始地址
一维数组的数组名为一维数组的指针(起始地址)
例如
double x[8];
因此,x为x数组的起始地址


设指针变量px的地址值等于数组指针x(即指针变量px指向数组的首元数),则:
x[i] 、(px+i)、(x+i) 和px[i]具有完全相同的功能:访问数组第i+1个数组元素。
第六节--指针专题一
注意:指针变量和数组在访问数组中元素时,一定条件下其使用方法具有相同的形式,因为指针变量和数组名都是地址量
但指针变量和数组的指针(或叫数组名)在本质上不同,指针变量是地址变量,而数组的指针是地址常量


例:int a[]={1,2,3,4,5,6,7,8,9,10}, *p = a, i;数组元素地址的正确表示是:
(A)&(a+1) (B)a++ (C)&p D)&p[i]
数组名是地址常量
p++,p-- (对)
a++,a-- (错)
a+1, *(a+2) (对)


程序举例
编写一个函数,将整形数组中n个数按反序存放


四、指针与二维数组

第六节--指针专题一
编程实现,使用一级指针遍历二维数组


可把二维数组看作由多个一维数组组成。
比如int a[3][3],含有三个元素:a[0]、a[1]、a[2]
元素a[0]、a[1]、a[2]都是一维数组名
第六节--指针专题一
二维数组名代表数组的起始地址,数组名加1,是移动一行元素。因此,二维数组名常被称为行地址
第六节--指针专题一
*行指针(数组指针)
存储行地址的指针变量,叫做行指针变量。形式如下:
<存储类型> <数据类型> (*<指针变量名>)[表达式] ;
例如,int a[2][3]; int (p)[3];
方括号中的常量表达式表示指针加1,移动几个数据。
当用行指针操作二维数组时,表达式一般写成1行的元素个数,即列数。

编程实现,使用行指针表示二维数组int a[2][4]的元素a[1][1]


总结与思考
主要介绍了指针与二维数组,包括一级指针如何访问二维数组以及行指针如何访问二维数组
思考
二维数组名有什么特点?
编程实现,使用行指针遍历二维数组?