指针变量的使用场合及常见的使用方法

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

指针变量的使用场合及常见的使用方法

一、处理简单变量(这里的简单变量指的是非下标变量)

1、函数定义简单变量,在本函数内处理该变量

(1) 直接访问(不用指针变量)

void f1()

{int a;

a = 5; //效率高

……

}

(2) 间接访问(用指针变量)

void f1()

{int a, *p;

p = &a;

*p = 5; //效率低

……

}

由于间接访问效率低,故一般不采用这种方法。

2、函数f1()定义简单变量,在本函数之外(另一函数f2()中)处理该变量

(1) 值传递(不用指针变量)

void f1()

{void f2(int, int);

int a = 5, b = 3;

f2(a,b);

……

}

void f2(int x, int y)

{

printf(“sum=%d\n”, x+y);

}

如果不希望被调函数f2()改变a、b的值,只允许它使用副本,通常用这种传递——值传递。

(2) 地址传递(用指针变量)

void f1()

{void f2(int*);

int a = 5;

f2(&a);

printf(“a = %d\n”, a);

}

void f2(int *p) //注意:是在被调函数中使用指针变量

{

*p = 1;

}

这种情况下,函数f2()中使用的*p就是f1()中的a(正本),可以通过p间接访问a并且可以改变a的值。

如果希望被调函数f2()改变a的值,只能用这种传递——地址传递。

二、处理下标变量

1、函数f1()定义数组,在本函数中访问下标变量

(1)直接访问(不用指针变量)

void f1()

{int a[10] = {3,1,5,8,7,9,6,2,0,4}, i;

for(i = 0; i <= 9; i++)

printf(“%3d”, a[i]); //用数组名访问——直接访问

printf(“\n”);

}

(2)间接访问(用指针变量)

void f1()

{int a[10] = {3,1,5,8,7,9,6,2,0,4}, i;

int *p;

for(p = 0; i <= a + 9; p++)

printf(“%3d”, *p); //用指针变量访问——间接访问

printf(“\n”);

}

这种方法比用数组名访问更高效,故也经常采用这种方法。

注意:

只有访问数组中多个连续的下标变量时,才用这种间接的方法,因为它高效。若只访问其中一个下标变量,则用间接访问比直接访问要慢。如:

直接访问:

a[5] = 1; //效率高

间接访问:

p = a;

*(p+5) = 1; //效率低

2、函数f1()定义数组,在本函数之外(另一函数f2()中)访问下标变量

(1) 值传递(不用指针变量)

f2()函数需要用几个数据,则f1()就应该传递几个数据,若所有数据都用,则需要传递所有数据。

void f1()

{void f2(int,int,……int); //共10个虚参

int a[10] = {3,1,5,8,7,9,6,2,0,4}

f2(a[0],a[1],a[2],…… a[9]); //共10个实参

}

void f2(int a,int b,int c,int d,……int j) //共10个虚参

{int sum;

sum = a + b + c + d + e + f + g + h + i + j;

printf(“sum = %d\n”, sum);

}

显然,这不是个好办法,因为这种设计使函数需要传递的参数太多,太麻烦。

所以,尽管这种值传递可以有效保护f1()中数组的数据,但仍然不被程序员所采用。

(2)地址传递(用指针变量)

void f1()

{void f2(int*);

int a[10] = {3,1,5,8,7,9,6,2,0,4}

f2(a); //数组名a作参数,而不是a[10],更不是int a[10]

}

void f2(int *p) //注意:是在被调函数中使用指针变量

{int *p0 = p, sum = 0;

for( ; p <= p0 + 9; p++)

sum += *p;

printf(“sum = %d\n”, sum);

}

只需要传递一个参数就可以了(因为数组中的下标变量是连续的,得到一个变量的地址,便可以访问到每一个变量)。

使用这种地址传递,使得f2()不仅可以使用数组a中的数据(如本例),还可以改变它们,其实有时候我们本来就希望被调函数f2()来改变数组中的数据(如:对数组清0,对数组排序等),此时必须采用这种传递。

下面是对数组排序的例子:

void f1()

{void f2(int*);

int a[10] = {3,1,5,8,7,9,6,2,0,4}

f2(a); //数组名a作参数,而不是a[10]

……//输出排序后的数组

}

void f2(int *p)

{int i,j,k,t;

for(i = 0; i < 9; i++)

{k = i;

for(j = i + 1; j <= 9; j++)

if(p[j] > p[k]) //p[j]等价于*(p+j)

k = j;

t = p[i];

p[i] = p[k];

p[k] = t;

}

}

相关文档
最新文档