Linux 版 (精华区)
发信人: netiscpu (夜☆星光点点☆), 信区: Linux
标 题: ◇ 星星流讲座 0035
发信站: 紫 丁 香 (Sun Nov 8 18:35:40 1998), 转信
寄信人: guest.bbs@hgluo.hust.edu.cn
标 题: ◇ 星星流讲座 0035
发信站: 华南理工大学 BBS木棉站
日 期: Thu Feb 20 14:54:02 1997
发信人: ax.bbs@bbs.ee.nthu.edu.tw. (athena), 信区: test
标 题: 星星流讲座 0035
发信站: ☆清华电机☆ (Thu Jul 6 21:41:10 1995)
;35m第 5 讲 之 11 阵列与指标
Topic: Multi-dimensional arraym
C 语言支援多维阵列,它的宣告方式很简单,例如我们要宣告一个
2x2 的整数阵列:
int a[2][2];
更高维数的依此类推:
int b[3][3][3];
请注意多维阵列在 C 中是以 a[1][2] 这种形式出现,和其他高阶语言常见
的 a(1,2) 或 a[1,2] 不同,这是容易犯错的地方。
C 语言以 row major 的方式来处理多维阵列,亦即
int a[2][2]; /* [row][column] */
多维阵列和指标阵列在资料的存放上有很大的不同,例如:
char *name[] = {"Susan", "Elizabeth", "Jay"};
char name[][10] = {"Susan", "Elizabeth", "Jay"};
上面的例子中,我们并没有给定第一维的维数,这是因为第一维的维数不
必给,compiler 会自己替你决定,但是第二维以後的维数你必须自己指定。
同样的情形也发生在把多维阵列当做函数的参数传递上,例如:
foo (a[][10]);
你m必须0m指定第二维以後的维数,否则将发生错误。为什麽?我们先卖
个关子。先来看看 *name[] 的存放方式和 name[][10] 有什麽不同,请看下图:
*name[]
┌┐ +-------+
│┼→|Susan\0|
├┤ +-------+---+
│┼→|Elizabeth\0|
├┤ +-----+-----+
│┼→|Jay\0|
└┘ +-----+
name[][10]
+-----------------------------------+
|Susan\0 Elizabeth\0 Jay\0 |
+-----------------------------------+
0 10 20
我们可以看到 name[][10] 是配置了 3 * 10 = 30 的空间,然後把二维阵列
转换成一维阵列储存,这也就是 C 语言对付多维阵列的方法:把它转化为一
维阵列存放。因此,m如果你在传递多维阵列时不给定第二维以後的维数的话,
compiler 就不能正确的计算阵列中各个元素存放的位置,因此会发生错误0m。
由上面的图形我们可以很明显的区分 *name[] 和 name[][10] 的差别,一般
而言以 *name[] 这种形式来存放资料是比较省空间的,但这并不绝对。
--
本文原作者为徐振家,原作刊载於星星神教总坛 ☆清华电机☆ 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)
页面执行时间:5.578毫秒