第八章指针及链表 第一课: 教学内容: 指针的概念,数组的指针,数组作函数参 数 教学目标: 理解指针的概念,为以后学习链表的相关知 识做准备 重点、难点 重点:地址和指针的概念 难点:指针的应用
第一课: 一、教学内容: 指针的概念,数组的指针,数组作函数参 数。 二、教学目标: 理解指针的概念,为以后学习链表的相关知 识做准备。 三、重点、难点 重点:地址和指针的概念。 难点:指针的应用。 第八章 指针及链表
(一)地址和指针的概念 首先、弄清楚数据在内存中是如何存储 的又是如何读取的 内存区每一个字节有一个编号,这就是 “地址”。可以由地址直接取数据。还可以 采用另一种称之为“间接访问”的方式,将 变量i的地址存放在另一个变量中。由于通过 地址能找到所需的变量单元,我们可以说, 地址“指向”该变量单元。地址就形象的称 为“指针”。 注意:形分“指针”和“指针变量”这两个 概念
(一)地址和指针的概念 首先、弄清楚数据在内存中是如何存储 的又是如何读取的。 内存区每一个字节有一个编号,这就是 “地址”。可以由地址直接取数据。还可以 采用另一种称之为“间接访问”的方式,将 变量i的地址存放在另一个变量中。由于通过 地址能找到所需的变量单元,我们可以说, 地址“指向”该变量单元。地址就形象的称 为“指针” 。 注意:形分“指针”和“指针变量”这两个 概念
(二)指针与指针变量 1、指针变量的定义 定义指针变量的一般形式为: 基类型*指针变量名 例:foat* pointer3 char *pointer 4 pointer 1=&i pointer_2=&j 2、指针变量的引用。 注意:&*D0 ointer 1 *&pointer_2 X xk&a=a pointer_1++先对 pointer_1的原值进行* 得到a的值,然后使 pointer_1的值改变
(二)指针与指针变量 1、指针变量的定义 定义指针变量的一般形式为: 基类型 *指针变量名 例: float *pointer_3 char *pointer_4 pointer_1=&i pointer_2=&j 2、指针变量的引用。 注意:&*pointer_1 *&pointer_2 x *&a=a *pointer_1++ 先对pointer_1的原值进行* , 得到a的值,然后使pointer_1的值改变
)数组的指针和指向数组的指针变量 指针变量既然可以指向变量,当然也可以指向数组和数组元素。 int *p int a[10] 两句等价 P=&a[o] 注意:a不代表整个数组。 如果p的初值为&a[0]则: 1、p+i和a+就是a[]的地址。 2、p[]与*(p+i)等价 根据以上叙述,引用一个数组元素,可以用: (1)下标法:a[i] (2)指针法:*(p+i
(三)数组的指针和指向数组的指针变量 指针变量既然可以指向变量,当然也可以指向数组和数组元素。 int *p int a[10] P=&a[0] P=a 注意:a不代表整个数组。 如果p的初值为&a[0],则: 1、p+i和a+i就是a[i]的地址。 2、p[i]与*(p+i)等价 根据以上叙述,引用一个数组元素,可以用: ⑴下标法:a[i] ⑵指针法:*(p+i) 两句等价
(四)数组名作函数参数 数组名作实参,在调用函数时是把 数组的首地址传送给形参,这样实参 数组与形参数组共占用一段内存。 例:将数组a中n个整数按相反顺序存放。 void inv(int *xint a) dint p, temp i *j, m=(n-1)/2i 1=x;j=x+n-1;p=x+m; for(;i<=p;+十j-) temp=*ii i=*ji j=temp;] return;
(四)数组名作函数参数 数组名作实参,在调用函数时是把 数组的首地址传送给形参,这样实参 数组与形参数组共占用一段内存。 例:将数组a中n个整数按相反顺序存放。 void inv (int *x,int a) { int *p, temp,*i,*j, m=(n-1)/2; i=x; j=x+n-1; p=x+m; for(;i<=p;i++,j--) {temp=*i; *i=*j; *j=temp;} return; }