Linux 版 (精华区)
发信人: netiscpu (夜☆星光点点☆), 信区: Linux
标 题: ◇ 星星流讲座 0034
发信站: 紫 丁 香 (Sun Nov 8 18:35:18 1998), 转信
寄信人: guest.bbs@hgluo.hust.edu.cn
标 题: ◇ 星星流讲座 0034
发信站: 华南理工大学 BBS木棉站
日 期: Thu Feb 20 14:50:37 1997
发信人: ax.bbs@bbs.ee.nthu.edu.tw. (athena), 信区: test
标 题: 星星流讲座 0034
发信站: ☆清华电机☆ (Thu Jul 6 13:57:40 1995)
;35m第 5 讲 之 10 阵列与指标
Topic: Differences between pointers and arraysm
我们前面的程式,如果把 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 会给我们错误
讯息呢?这是因为m阵列虽然可以用指标的观念来看待,但是对编译器而言,
阵列与指标的资料型态 (data type) 并不相同0m。由於阵列的资料型态不可以
使用 ++ 这个运算元 (你想 ++ 阵列的那一个元素呢?),所以这个程式会在
编译时发生错误。请你看看下面的程式比较一下:
/* 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 (mchar **lineptr0m)
阵列在传给 foo 这个函数之前,已经经由m隐含的型态转换0m转变成
char ** 型态了,而非原来宣告的 * char [] 型态,所以可以安心地
使用 ++ 这个运算元。
--
本文原作者为徐振家,原作刊载於星星神教总坛 ☆清华电机☆ test 板。
你可以以电子文件的形式将本文自由流传於台湾学术网路,但必须包含此版权声明。
原作者依中华民国著作权法之规定,享有本文之著作权,请勿抄袭以免触法。
未经授权任何人不得以任何形式对本文做任何修改及商业上之应用。
其他网路的转载或其他用途的应用,请先知会作者,并取得其同意。
对本文有任何疑问或意见请 mail 给 ax.bbs@bbs.ee.nthu.edu.tw,谢谢。
--
m;32m※ 转寄:.华南网木棉站 bbs.gznet.edu.cn.[FROM: mtlab.hit.edu.cn]
--
Enjoy Linux!
-----It's FREE!-----
※ 来源:.紫 丁 香 bbs.hit.edu.cn.[FROM: mtlab.hit.edu.cn]
Powered by KBS BBS 2.0 (http://dev.kcn.cn)
页面执行时间:4.500毫秒