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水木清华站∶精华区