数组与指针的区别

数组要么在静态存储区被创建(如全局数组),要么在栈上被创建。指针可以随时指向任意类型的内存块。

(1)修改内容上的差别

char a[] = “hello”;

a[0] = ‘X’;

char *p = “world”; // 注意p 指向常量字符串

p[0] = ‘X’; // 编译器不能发现该错误,运行时错误

(2)内容复制与比较

不能对数组名进行直接复制与比较,而应用库函数strcpy比较则是strcmp.

(3)数组名为其首地址,是不能被修改的,也不能有运算符进行运算。(数组地址与容量在生命期内保持不变,只是数组的内容可以改变)

(4)用运算符sizeof 可以计算出数组的容量(字节数)。sizeof(p),p 为指针得到的是一个指针变量的字节数,而不是p 所指的内存容量。C++/C 语言没有办法知道指针所指的内存容量,除非在申请内存时记住它。注意当数组作为函数的参数进行传递时,该数组自动退化为同类型的指针。

char a[] = "hello world";

char *p = a;

cout<< sizeof(a) << endl; // 12 字节

cout<< sizeof(p) << endl; // 4 字节

计算数组和指针的内存容量

void Func(char a[100])

{

cout<< sizeof(a) << endl; // 4 字节而不是100 字节

}

(5)数组名不是指针,但是在一定的情况下转换为指代数组的首地址的指针,而这数组名转为的指针只能是指针常量

a. 将数组名直接赋值给指针,数组名转换为指向数组的首单元的常量指针。

void fun(char str[])

b.直接将数组名作为指针形参的时候,数组名则转换为指向数组的首单元的常量指针进行传递,如下程序2:

char str1[5];
fun(str1);

数组名作为函数形参进行传递时,在子函数体内,它已经不再是一个指针常量,而是变成一个真正的指针,可以进行增减等操作,可以被修改。所以程序2中子程序第一条语句输出的sizeof(str)的值为4.

(6)访问的方式不一样

char str[7]=”ksarea”;

char *pstr=str;

 cout<< str[3]<<pstr[3]<<endl;

其中str[3]和pstr[3]返回的都是字符’r‘,但是编译器产生的执行代码却不一样。对于str[3],执行代码是从str开始,向后移动三个字节,然后取出其中的字符;而对于pstr[3],执行代码是从pstr中取出地址,然后在其上加3,然后取出对应内存中的字符。当然,如果pstr是指向int型的指针,那么pstr[3]的处理过程是从pstr中取出地址,然后在其上加上3*sizeof(int),最后取出对应内存中的字符,其他的数据类型一次类推。

 

 

posted on 2012-08-25 17:00  走出地平线  阅读(90)  评论(0)    收藏  举报