指针的指针和指向指针数组的指针

来源:本站
导读:目前正在解读《指针的指针和指向指针数组的指针》的相关信息,《指针的指针和指向指针数组的指针》是由用户自行发布的知识型内容!下面请观看由(电工技术网 - www.9ddd.net)用户发布《指针的指针和指向指针数组的指针》的详细说明。
简介:文章主要介绍了指针的指针和指向指针数组的指针之间的区别和关系

指针的指针

指针的指针看上去有些令人费解。它们的声明有两个星号。例如:

char**cp;

如果有三个星号,那就是指针的指针的指针,四个星号就是指针的指针的指针的指针,依次类推。当你熟悉了简单的例子以后,就可以应付复杂的情况了。当然,实际程序中,一般也只用到 二级指针,三个星号不常见,更别说四个星号了。

指针的指针需要用到指针的地址。

charc='A';

char*p=&c;

char**cp=&p;

通过指针的指针,不仅可以访问它指向的指针,还可以访问它指向的指针所指向的数据。下面就是几个这样的例子:

char*p1=*cp;

charc1=**cp;

你可能想知道这样的结构有什么用。利用指针的指针可以允许被调用函数修改局部指针变量和处理指针数组。

voidFindCredit(int**);

main()

{

intvals[]={7,6,5,-4,3,2,1,0};

int*fp=vals;

FindCredit(&fp);

printf(%dn,*fp);

}

voidFindCredit(int**fpp)

{

while(**fpp!=0)

if(**fpp<0)break;

else(*fpp)++;

}

首先用一个数组的地址初始化指针fp,然后把该指针的地址作为实参传递给函数FindCredit()。FindCredit()函数通过表达式**fpp间接地得到数组中的数据。为遍历数组以找到一个负值,FindCredit()函数进行自增运算的对象是调用者的指向数组的指针,而不是它自己的指向调用者指针的指针。语句(*fpp)++就是对形参指针指向的指针进行自增运算的。但是因为*运算符高于++运算符,所以圆括号在这里是必须的,如果没有圆括号,那么++运算符将作用于二重指针fpp上。

指向指针数组的指针

指针的指针另一用法旧处理指针数组。有些程序员喜欢用指针数组来代替多维数组,一个常见的用法就是处理字符串。

char*Names[]=

{

Bill,

Sam,

Jim,

Paul,

Charles,

0

};

main()

{

char**nm=Names;

while(*nm!=0)printf(%sn,*nm++);

}

先用字符型指针数组Names的地址来初始化指针nm。每次printf()的调用都首先传递指针nm指向的字符型指针,然后对nm进行自增运算使其指向数组的下一个元素(还是指针)。注意完成上述认为的语法为*nm++,它首先取得指针指向的内容,然后使指针自增。

注意数组中的最后一个元素被初始化为0,while循环以次来判断是否到了数组末尾。具有零值的指针常常被用做循环数组的终止符。程序员称零值指针为空指针(NULL)。采用空指针作为终止符,在树种增删元素时,就不必改动遍历数组的代码,因为此时数组仍然以空指针作为结束。

提醒:《指针的指针和指向指针数组的指针》最后刷新时间 2024-03-14 01:10:49,本站为公益型个人网站,仅供个人学习和记录信息,不进行任何商业性质的盈利。如果内容、图片资源失效或内容涉及侵权,请反馈至,我们会及时处理。本站只保证内容的可读性,无法保证真实性,《指针的指针和指向指针数组的指针》该内容的真实性请自行鉴别。