数组与指针的区别
数组要么在静态存储区被创建(如全局数组),要么在栈上被创建。指针可以随时指向任意类型的内存块。
(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),最后取出对应内存中的字符,其他的数据类型一次类推。
浙公网安备 33010602011771号