11.20C语言----数组&指针
2013-11-20 18:54
190 查看
今天学习C语言小结:
第一点:
指针变量的运算
1) 赋值运算:指针变量的赋值运算有以下几种形式。
① 指针变量初始化赋值,前面已作介绍。
② 把一个变量的地址赋予指向相同数据类型的指针变量。
例如:
int a,*pa;
pa=&a; /*把整型变量a的地址赋予整型指针变量pa*/
③ 把一个指针变量的值赋予指向相同类型变量的另一个指针变量。
如:
int a,*pa=&a,*pb;
pb=pa; /*把a的地址赋予指针变量pb*/
由于pa,pb均为指向整型变量的指针变量,因此可以相互赋值。
④ 把数组的首地址赋予指向数组的指针变量。
例如:
int a[5],*pa;
pa=a;
(数组名表示数组的首地址,故可赋予指向数组的指针变量pa)
也可写为:
pa=&a[0]; /*数组第一个元素的地址也是整个数组的首地址,也可赋予pa*/
当然也可采取初始化赋值的方法:
int a[5],*pa=a;
⑤ 把字符串的首地址赋予指向字符类型的指针变量。
例如:
char *pc;
pc="C Language";
或用初始化赋值的方法写为:
char *pc="CLanguage";
这里应说明的是并不是把整个字符串装入指针变量,而是把存放该字符串的字符数组的首地址装入指针变量。在后面还将详细介绍。
⑥ 把函数的入口地址赋予指向函数的指针变量。
例如:
int (*pf)();
pf=f; /*f为函数名*/
第二点:
加减算术运算
1)对于指向数组的指针变量,可以加上或减去一个整数n。设pa是指向数组a的指针变量,则pa+n,pa-n,pa++,++pa,pa--,--pa运算都是合法的。指针变量加或减一个整数n的意义是把指针指向的当前位置(指向某数组元素)向前或向后移动n个位置。不过要注意的是,数组指针变量向前或向后移动一个位置和地址加1或减1在概念上是不同的。因为数组可以有不同的类型,各种类型的数组元素所占的字节长度是不同的。如指针变量加1,即向后移动1 个位置表示指针变量指向下一个数据元素的首地址。而不是在原地址基础上加1。例如:
int a[5],*pa;
pa=a; /*pa指向数组a,也是指向a[0]*/
pa=pa+2; /*pa指向a[2],即pa的值为&pa[2]*/
指针变量的加减运算只能对数组指针变量进行,对指向其它类型变量的指针变量作加减运算是毫无意义的。
2)两个指针变量之间的运算:只有指向同一数组的两个指针变量之间才能进行运算,否则运算毫无意义。
① 两指针变量相减:两指针变量相减所得之差是两个指针所指数组元素之间相差的元素个数。实际上是两个指针值(地址)相减之差再除以该数组元素的长度(字节数)。例如pf1和pf2是指向同一浮点数组的两个指针变量,设pf1的值为2010H,pf2的值为2000H,而浮点数组每个元素占4个字节,所以pf1-pf2的结果为(2000H-2010H)/4=4,表示pf1和 pf2之间相差4个元素。两个指针变量不能进行加法运算。例如,pf1+pf2是什么意思呢?毫无实际意义。
② 两指针变量进行关系运算:指向同一数组的两指针变量进行关系运算可表示它们所指数组元素之间的关系。
例如:
pf1==pf2表示pf1和pf2指向同一数组元素;
pf1>pf2表示pf1处于高地址位置;
pf1<pf2表示pf2处于低地址位置。
指针变量还可以与0比较。
设p为指针变量,则p==0表明p是空指针,它不指向任何变量;
p!=0表示p不是空指针。
空指针是由对指针变量赋予0值而得到的。
例如:
#define NULL 0
int *p=NULL;
对指针变量赋0值和不赋值是不同的。指针变量未赋值时,可以是任意值,是不能使用的。否则将造成意外错误。而指针变量赋0值后,则可以使用,只是它不指向具体的变量而已。
例子:(我已调试)
第三点:
数组指针和指向数组的指针变量;一个变量有一个地址,一个数组包含若干元素,每个数组元素都在内存中占用存储单元,它们都有相应的地址。所谓数组的指针是指数组的起始地址,数组元素的指针是数组元素的地址。
(1)指向数组元素的指针
一个数组是由连续的一块内存单元组成的。数组名就是这块连续内存单元的首地址。一个数组也是由各个数组元素(下标变量)组成的。每个数组元素按其类型不同占有几个连续的内存单元。一个数组元素的首地址也是指它所占有的几个内存单元的首地址。
例:int a[10]; /*定义a为包含10个整型数据的数组*/
int *p; /*定义p为指向整型变量的指针*/
应当注意,因为数组为int型,所以指针变量也应为指向int型的指针变量。下面是对指针变量赋值:p=&a[0];把a[0]元素的地址赋给指针变量p。也就是说,p指向a数组的第0号元素。如下图所示:
(2)通过指针引用数组元素
我们知道C语言中有这样子规定:如果指针变量p已指向数组中的一个元素,则p+1指向同一数组中的下一个元素。引入指针变量后,就可以用两种方法来访问数组元素了。对于这个我用一个图形来表示并说明一下吧,如下图:
如果p的初值为&a[0],则:
1)p+i和a+i就是a[i]的地址,或者说它们指向a数组的第i个元素。
2)*(p+i)或*(a+i)就是p+i或a+i所指向的数组元素,即a[i]。例如,*(p+5)或*(a+5)就是a[5]。
3)指向数组的指针变量也可以带下标,如p[i]与*(p+i)等价。
好了,今天的小结就先写到这里吧~~明天继续加油!
第一点:
指针变量的运算
1) 赋值运算:指针变量的赋值运算有以下几种形式。
① 指针变量初始化赋值,前面已作介绍。
② 把一个变量的地址赋予指向相同数据类型的指针变量。
例如:
int a,*pa;
pa=&a; /*把整型变量a的地址赋予整型指针变量pa*/
③ 把一个指针变量的值赋予指向相同类型变量的另一个指针变量。
如:
int a,*pa=&a,*pb;
pb=pa; /*把a的地址赋予指针变量pb*/
由于pa,pb均为指向整型变量的指针变量,因此可以相互赋值。
④ 把数组的首地址赋予指向数组的指针变量。
例如:
int a[5],*pa;
pa=a;
(数组名表示数组的首地址,故可赋予指向数组的指针变量pa)
也可写为:
pa=&a[0]; /*数组第一个元素的地址也是整个数组的首地址,也可赋予pa*/
当然也可采取初始化赋值的方法:
int a[5],*pa=a;
⑤ 把字符串的首地址赋予指向字符类型的指针变量。
例如:
char *pc;
pc="C Language";
或用初始化赋值的方法写为:
char *pc="CLanguage";
这里应说明的是并不是把整个字符串装入指针变量,而是把存放该字符串的字符数组的首地址装入指针变量。在后面还将详细介绍。
⑥ 把函数的入口地址赋予指向函数的指针变量。
例如:
int (*pf)();
pf=f; /*f为函数名*/
第二点:
加减算术运算
1)对于指向数组的指针变量,可以加上或减去一个整数n。设pa是指向数组a的指针变量,则pa+n,pa-n,pa++,++pa,pa--,--pa运算都是合法的。指针变量加或减一个整数n的意义是把指针指向的当前位置(指向某数组元素)向前或向后移动n个位置。不过要注意的是,数组指针变量向前或向后移动一个位置和地址加1或减1在概念上是不同的。因为数组可以有不同的类型,各种类型的数组元素所占的字节长度是不同的。如指针变量加1,即向后移动1 个位置表示指针变量指向下一个数据元素的首地址。而不是在原地址基础上加1。例如:
int a[5],*pa;
pa=a; /*pa指向数组a,也是指向a[0]*/
pa=pa+2; /*pa指向a[2],即pa的值为&pa[2]*/
指针变量的加减运算只能对数组指针变量进行,对指向其它类型变量的指针变量作加减运算是毫无意义的。
2)两个指针变量之间的运算:只有指向同一数组的两个指针变量之间才能进行运算,否则运算毫无意义。
① 两指针变量相减:两指针变量相减所得之差是两个指针所指数组元素之间相差的元素个数。实际上是两个指针值(地址)相减之差再除以该数组元素的长度(字节数)。例如pf1和pf2是指向同一浮点数组的两个指针变量,设pf1的值为2010H,pf2的值为2000H,而浮点数组每个元素占4个字节,所以pf1-pf2的结果为(2000H-2010H)/4=4,表示pf1和 pf2之间相差4个元素。两个指针变量不能进行加法运算。例如,pf1+pf2是什么意思呢?毫无实际意义。
② 两指针变量进行关系运算:指向同一数组的两指针变量进行关系运算可表示它们所指数组元素之间的关系。
例如:
pf1==pf2表示pf1和pf2指向同一数组元素;
pf1>pf2表示pf1处于高地址位置;
pf1<pf2表示pf2处于低地址位置。
指针变量还可以与0比较。
设p为指针变量,则p==0表明p是空指针,它不指向任何变量;
p!=0表示p不是空指针。
空指针是由对指针变量赋予0值而得到的。
例如:
#define NULL 0
int *p=NULL;
对指针变量赋0值和不赋值是不同的。指针变量未赋值时,可以是任意值,是不能使用的。否则将造成意外错误。而指针变量赋0值后,则可以使用,只是它不指向具体的变量而已。
例子:(我已调试)
第三点:
数组指针和指向数组的指针变量;一个变量有一个地址,一个数组包含若干元素,每个数组元素都在内存中占用存储单元,它们都有相应的地址。所谓数组的指针是指数组的起始地址,数组元素的指针是数组元素的地址。
(1)指向数组元素的指针
一个数组是由连续的一块内存单元组成的。数组名就是这块连续内存单元的首地址。一个数组也是由各个数组元素(下标变量)组成的。每个数组元素按其类型不同占有几个连续的内存单元。一个数组元素的首地址也是指它所占有的几个内存单元的首地址。
例:int a[10]; /*定义a为包含10个整型数据的数组*/
int *p; /*定义p为指向整型变量的指针*/
应当注意,因为数组为int型,所以指针变量也应为指向int型的指针变量。下面是对指针变量赋值:p=&a[0];把a[0]元素的地址赋给指针变量p。也就是说,p指向a数组的第0号元素。如下图所示:
(2)通过指针引用数组元素
我们知道C语言中有这样子规定:如果指针变量p已指向数组中的一个元素,则p+1指向同一数组中的下一个元素。引入指针变量后,就可以用两种方法来访问数组元素了。对于这个我用一个图形来表示并说明一下吧,如下图:
如果p的初值为&a[0],则:
1)p+i和a+i就是a[i]的地址,或者说它们指向a数组的第i个元素。
2)*(p+i)或*(a+i)就是p+i或a+i所指向的数组元素,即a[i]。例如,*(p+5)或*(a+5)就是a[5]。
3)指向数组的指针变量也可以带下标,如p[i]与*(p+i)等价。
好了,今天的小结就先写到这里吧~~明天继续加油!
相关文章推荐
- <<C语言深度剖析>>学习笔记之五:指针与数组
- go语言笔记——切片底层本质是共享数组内存!!!绝对不要用指针指向 slice切片本身已经是一个引用类型就是指针
- C程序设计语言--指针与数组(二) 指针数组 数组指针 函数指针 指针函数
- 通过数组初始化链表的两种方法:指向指针的引用node *&tail和指向指针的指针(二维指针)node **tail
- 数组&指针
- c语言指针,数组
- C程序设计语言(K&R)学习笔记--8.指针与数组
- c 语言 数组与指向指针的指针 浅谈
- C语言深度解剖(精讲版)——读书笔记18 -指针数组&&数组指针
- 内存的堆分配和栈分配 & 字符数组,字符指针,Sizeof总结
- 指针数组&nbsp;与数组指针
- C++编程入门系列之二十七(数组、指针和字符串:指针变量的声明、地址相关运算--“*”和“&”)
- 程序猿之--C语言细节13(二维数组和指针,&*a[i][0]的理解,数组1[e]和e[1]很可能你没见过)
- 指针数组 数组指针 observer && pure virtual func
- 内存的堆分配和栈分配 & 字符数组,字符指针,Sizeof总结
- C语言基础-指针与数组
- C语言基础 指针与数组
- 20151215C语言基础16_函数3(数组与指针)
- 学点 C 语言(21): 数据类型 - 数组与指针
- C语言----指针和数组(1)