口指针变量的定义的一般格式为: 类型标识符*指针变量名 ■例如: int“p float火 q9 指针变量的引用: 必须先定义,后使用 指针变量定义后,可以对其进行如下操作: 赋值 用指针我量的值,访间指针变量指向的变量等 如上例中通过p1、p2访问变量a、b对应的单元,其 p1表示指针变量,pl表示p1指向的变量(即变量a), &p1表示指针变量p1所在单元的地址
◼ 指针变量的定义的一般格式为: 类型标识符 *指针变量名 ◼ 例如: int *p; float *q; ◼ 指针变量的引用: 必须先定义,后使用 指针变量定义后,可以对其进行如下操作: 赋值、引用指针变量的值、访问指针变量指向的变量等。 如上例中通过p1、p2访问变量a、b对应的单元,其 中 p1表示指针变量, *p1表示p1指向的变量(即变量a), &p1表示指针变量p1所在单元的地址
回顾例10.2:通过指针变量pl,p2交换了变量a和b的值 那么,为什么要用指针变量而不直接用变量名呢? 再回顾函数一章的例84:编写函数swap(交换两个变量的值, 函数如下: viod swap( int a, int b f intt; t=a; a=b; b=t; 3 maino f int x=5, y=6 swap(x, y) printf("nx=%d, y=%",x, y) 结果:x=5y=6 程序并未实现交换x、y的值,why? 因为参数传递是单向的,对形参的改变不影响实参的值
回顾例10.2:通过指针变量p1,p2交换了变量a和b的值。 那么,为什么要用指针变量而不直接用变量名呢? 再回顾函数一章的例8.4:编写函数swap()交换两个变量的值, 函数如下: viod swap( int a, int b) { int t; t=a; a=b; b=t;} main() { int x=5,y=6; swap(x,y); printf("\nx=%d,y=%d",x,y);} 结果:x=5,y=6 程序并未实现交换x、y的值, why? 因为参数传递是单向的,对形参的改变不影响实参的值
指针变量作函数参数 解决以上问题的方法是: 指向变量的指针变量作函数形参,接收主调函数 中实参变量的地址,实现传地址调用。 即在被调函数中通过指针变量访问(读取或修改) 主调函数中对应的变量,当返回主调函数后 主调函数就得到了这些已修改过的变量的值 因此,“传地址”调用可以实现函数间多个数 据的“双向传递
指针变量作函数参数 解决以上问题的方法是: 指向变量的指针变量作函数形参,接收主调函数 中实参变量的地址,实现传地址调用。 即在被调函数中通过指针变量访问(读取或修改) 主调函数中对应的变量,当返回主调函数后, 主调函数就得到了这些已修改过的变量的值。 因此,“传地址”调用可以实现函数间多个数 据的“双向传递
maino/编写函数交换两个变量的值* fint a, b void swap(int *p, int*q; printf("in input 2 integers: ) scanf(%od% od", &a, &b); printf(" in before swap: a=%d, b=%d", a, b) swap(, &b)3 printf( in after swap: a=%d, b=d a, b); oid swap(intap,lnt)交换两个变量的值* ;p=05=r3
main() /*编写函数交换两个变量的值*/ { int a,b; void swap(int *p,int *q); printf("\n input 2 integers:"); scanf("%d%d",&a,&b); printf("\n before swap:a=%d,b=%d",a,b); swap(&a, &b); printf("\n after swap:a=%d,b=%d",a,b); } void swap(int *p,int *q) /*交换两个变量的值*/ { int t; t=*p; *p=*q;*q=t; }
调用过程中参数的对应关系: Main swap p b &b p a q 因此,在swap函数中通过指针变量p、q就可以访问main 函数中的变量a、b了。由此可以实现函数之间的多个 数据传递
调用过程中参数的对应关系: Main: swap: a p b q *p a *q b 因此,在swap函数中通过指针变量p、q就可以访问main 函数中的变量a、b了。由此可以实现函数之间的多个 “数据传递”。 &a &b