BBS水木清华站∶精华区

发信人: ax.bbs@bbs.ee.nthu.edu.tw. (athena), 信区: test 
标  题: 星星流讲座 0035 
发信站: ☆清华电机☆ (Thu Jul  6 21:41:10 1995) 
 
 
第 5 讲 之 11           阵列与指标 
                        Topic: Multi-dimensional array 
 
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]); 
 
你必须指定第二维以後的维数,否则将发生错误。为什麽?我们先卖 
个关子。先来看看 *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 语言对付多维阵列的方法:把它转化为一 
维阵列存放。因此,如果你在传递多维阵列时不给定第二维以後的维数的话, 
compiler 就不能正确的计算阵列中各个元素存放的位置,因此会发生错误。 
由上面的图形我们可以很明显的区分 *name[] 和 name[][10] 的差别,一般 
而言以 *name[] 这种形式来存放资料是比较省空间的,但这并不绝对。 
 
-- 
本文原作者为徐振家,原作刊载於星星神教总坛 ☆清华电机☆ test 板。 
你可以以电子文件的形式将本文自由流传於台湾学术网路,但必须包含此版权声明。 
原作者依中华民国著作权法之规定,享有本文之著作权,请勿抄袭以免触法。 
未经授权任何人不得以任何形式对本文做任何修改及商业上之应用。 
其他网路的转载或其他用途的应用,请先知会作者,并取得其同意。 
对本文有任何疑问或意见请 mail 给 ax.bbs@bbs.ee.nthu.edu.tw,谢谢。 
 
 

BBS水木清华站∶精华区