BBS水木清华站∶精华区
发信人: ax.bbs@bbs.ee.nthu.edu.tw. (athena), 信区: test
标 题: 星星流讲座 0034
发信站: ☆清华电机☆ (Thu Jul 6 13:57:40 1995)
第 5 讲 之 10 阵列与指标
Topic: Differences between pointers and arrays
我们前面的程式,如果把 printf 改一改,会得到三种不同的结果:
1. printf ("%s %s\n", lineptr[0], *(lineptr + 1));
执行结果:
I am a student I am a teacher
2. printf ("%s %s\n", lineptr[0], *(++lineptr));
wrong type argument to increment
3. printf ("%s\n", ++*lineptr);
执行结果:
am a student
先看第三个,++*lineptr 的意思是把 *lineptr 加 1。那 *lineptr 又是
什麽东西呢? *lineptr 就是指向 I am a student 这个字串的指标,你把
这个指标加 1,这个时候字串开头的字元 I 自然被「吃掉」了,所以执行
结果变成只剩 am a student 被印出来。
比较有意思的问题是,第一个是把 lineptr 加 1 之後,印出它所指向的字
串,也就是第一个相当於
printf ("%s %s\n", lineptr[0], lineptr[1]);
但是第二个 printf 也是把 lineptr 加 1,为什麽 compiler 会给我们错误
讯息呢?这是因为阵列虽然可以用指标的观念来看待,但是对编译器而言,
阵列与指标的资料型态 (data type) 并不相同。由於阵列的资料型态不可以
使用 ++ 这个运算元 (你想 ++ 阵列的那一个元素呢?),所以这个程式会在
编译时发生错误。请你看看下面的程式比较一下:
/* pa.c */
#include <stdio.h>
#include <string.h>
void foo (char **lineptr);
void main (void)
{
char s1[20], s2[20], s3[20];
char *lineptr[3];
strcpy (s1, "I am a student");
strcpy (s2, "I am a teacher");
strcpy (s3, "I am an audiance");
lineptr[0] = s1;
lineptr[1] = s2;
lineptr[2] = s3;
foo (lineptr);
}
void foo (char **lineptr)
{
printf ("%s\n", *++lineptr);
}
执行结果:
I am a teacher
这里为什麽就可以这样儿做了呢?请看 foo 的参数:
void foo (char **lineptr)
阵列在传给 foo 这个函数之前,已经经由隐含的型态转换转变成
char ** 型态了,而非原来宣告的 * char [] 型态,所以可以安心地
使用 ++ 这个运算元。
--
本文原作者为徐振家,原作刊载於星星神教总坛 ☆清华电机☆ test 板。
你可以以电子文件的形式将本文自由流传於台湾学术网路,但必须包含此版权声明。
原作者依中华民国著作权法之规定,享有本文之著作权,请勿抄袭以免触法。
未经授权任何人不得以任何形式对本文做任何修改及商业上之应用。
其他网路的转载或其他用途的应用,请先知会作者,并取得其同意。
对本文有任何疑问或意见请 mail 给 ax.bbs@bbs.ee.nthu.edu.tw,谢谢。
BBS水木清华站∶精华区