一、什么时候数组和指针是相同的
1、表达式中的数组名(与声明不同)被编译器当作一个指向该数组第一个元素的指针
因此如a[i]这样的访问都被编译器改写或解释为*(a+i)的形式,同样取下标操作符的操作数是可交换的,所以a[3]可以写成3[a],不过通常你不会这样做。
2、下标总是与指针的偏移量相同,下标*sizeof(元素类型)就是偏移数组起始地址的实际字节数。
3、“作为函数参数的数组名”等同于指针,任何传递给函数的数组参数都会被转换成指针,这是基于效率考虑,避免了数组的拷贝。在函数内部,数组参数都将被转换成一个指针,要牢记这一点,因此如:
void test( char a[ 10 ]) { printf( " %d\n " , sizeof (a)); } 显然应该打印指针大小4,而非数组大小。另外,注意数组参数的地址跟数组参数第一个元素的地址并不相等,在表达式中两者一致,但是在函数调用中,由于数组参数指针也是临时变量,因此两者的地址是不一样的。
可以通过下列程序观察:
#include < stdio.h > #include < stdlib.h > void test1( char a[]) { printf( " &a=%x,&(a[0])=%x,&(a[1])=%x\n " , & a, & (a[ 0 ]), & (a[ 1 ])); } void test2( char * b) { printf( " &b=%x,&(b[0])=%x,&(b[1])=%x\n " , & b, & (b[ 0 ]), & (b[ 1 ])); } int main( int argc, char * argv[]) { char ga[] = " hello " ; printf( " &ga=%x,&(ga[0])=%x,&(ga[1])=%x\n " , & ga, & (ga[ 0 ]), & (ga[ 1 ])); test1(ga); test2(ga); system( " pause " ); return 0 ; } 二、指针跟数组什么时候不同
1、如果定义了一个数组,在其他文件对它进行声明也必须声明为数组,定义和声明必须匹配,指针也是如此。
2、指针始终是指针,它绝不可以写成数组。可以用下标形式访问指针的时候,一般都是指针作为函数参数时,并且你知道传递给函数的实际是一个数组。
3、数组名是不可改变的左值,因此如
int array[ 100 ],array2[ 100 ]; array = array2; array++; array--; 都将出错,但是在函数内部:
int array2[ 100 ]; void fun( int array[]) { array = array2; } 却可以,因为在函数内部array虽然被声明为数组实际上却是指针。
文章转自庄周梦蝶 ,原文发布时间2009-02-17