分类: C/C++
2007-06-22 11:03:36
水滴石穿C语言之指针、数组和函数 | ||||||
---|---|---|---|---|---|---|
| ||||||
2004年10月15日 15:57 天极yesky | ||||||
文/楚云风 基本解释1、指针的本质是一个与地址相关的复合类型,它的值是数据存放的位置(地址);数组的本质则是一系列的变量。 2、数组名对应着(而不是指向)一块内存,其地址与容量在生命期内保持不变,只有数组的内容可以改变。指针可以随时指向任意类型的内存块,它的特征是“可变”,所以我们常用指针来操作动态内存。 3、当数组作为函数的参数进行传递时,该数组自动退化为同类型的指针。 问题:指针与数组 听说char a[]与char *a是一致的,是不是这样呢? 答案与分析: 指针和数组存在着一些本质的区别。当然,在某种情况下,比如数组作为函数的参数进行传递时,由于该数组自动退化为同类型的指针,所以在函数内部,作为函数参数传递进来的指针与数组确实具有一定的一致性,但这只是一种比较特殊的情况而已,在本质上,两者是有区别的。请看以下的例子:
上述两个变量的内存布局分别如下: 数组a需要在内存中占用8个字节的空间,这段内存区通过名字a来标志。指针p则需要4个字节的空间来存放地址,这4个字节用名字p来标志。其中存放的地址几乎可以指向任何地方,也可以哪里都不指,即空指针。目前这个p指向某地连续的8个字节,即字符串“Hi, pig!”。 另外,例如:对于a[2]和p[2],二者都返回字符‘i’,但是编译器产生的执行代码却不一样。对于a[2],执行代码是从a的位置开始,向后移 动2两个字节,然后取出其中的字符。对于p[2],执行代码是从p的位置取出一个地址,在其上加2,然后取出对应内存中的字符。 问题:数组指针 为什么在有些时候我们需要定义指向数组而不是指向数组元素的指针?如何定义? 答案与分析: 使用指针,目的是用来保存某个元素的地址,从而来利用指针独有的优点,那么在元素需要是数组的情况下,就理所当然要用到指向数组的指针,比如在高维需要动态生成情况下的多维数组。 定义例子如下: int (*pElement)[2]。 下面是一个例子:
上述这个例子充分说明了数组指针—一种指向整个数组的指针的定义和使用。 需要说明的是,按照我们在第四篇讨论过的,指针的步进是参照其所指对象的大小的,因此,pa++将整个向后移 动一个数组的尺寸,而不是仅仅向后移 动一个数组元素的尺寸。 问题:指针数组 有如下定义:
问题:指向指针的指针
问题:指针数组与数组指针与指向指针的指针 指针和数组分别有如下的特征: 指针:动态分配,初始空间小 数组:索引方便,初始空间大 下面使用高维数组来说明指针数组、数组指针、指向指针的指针各自的适合场合。 多维静态数组:各维均确定,适用于整体空间需求不大的场合,此结构可方便索引,例a[10][40]。 数组指针:低维确定,高维需要动态生成的场合,例a[x][40]。 指针数组:高维确定,低维需要动态生成的场合,例a[10][y]。 指向指针的指针:高、低维均需要动态生成的场合,例a[x][y]。 问题:数组名相关问题 假设有一个整数数组a,a和&a的区别是什么? 答案与分析: a == &a == &a[0],数组名a不占用存储空间。需要引用数组(非字符串)首地址的地方,我一般使用&a[0],使用a容易和指针混淆,使用&a容易和非指针变量混淆。 区别在于二者的类型。对数组a的直接引用将产生一个指向数组第一个元素的指针,而&a的结果则产生一个指向全部数组的指针。例如:
问题:函数指针与指针函数 请问:如下定义是什么意思:
答案与分析: 首先清楚它们的定义: 指针函数,返回一个指针的函数。 函数指针,指向一个函数的指针。 可知: pF1是一个指针函数,它返回一个指向int型数据的指针。 pF2是一个函数指针,它指向一个参数为空的函数,这个函数返回一个整数。 |
chinaunix网友2008-03-07 13:52:23
pF2是一个函数指针,它指向一个参数为空的函数,这个函数返回一个整数。 这句话有问题 int (*pF2)(void); 才是 int (*pF2)();pF2应该可以指向任何返回一个整数的函数