char* a = "zhf";
定义一个 指针 a,
指向一个 常量字符串 "zhf" 的首地址,
由于 "zhf" 是一个常量字符串, 在常量区,无法修改,所以 a[1] = 'k' 出错,它意图修改常量;
但是 a 这个指针本身是可以修改的。
char a[] = "zhf";
定义一个 char 数组,
该数组的内容是 "zhf", 这里有一个赋值,
"zhf" 被赋值给了这个数组, 数组中的值是可以修改的,
也就是 a[1] = 'k' 是允许的;
但是 数组名 是const 属性的, 不能修改。
--------------------
char *a[]="aaaaaaa";
char *b="bbbbbbb";
aaaaaaaaaaa是在运行时刻赋值的;
而bbbbbbbbbbb是在编译时就确定的;
但是,在以后的存取中,在栈上的数组比指针所指向的字符串(例如堆)快。
对应的汇编代码
10:a=c[1];
004010678A4DF1movcl,byteptr[ebp-0Fh]
0040106A884DFCmovbyteptr[ebp-4],cl
11:a=p[1];
0040106D8B55ECmovedx,dwordptr[ebp-14h]
004010708A4201moval,byteptr[edx+1]
004010738845FCmovbyteptr[ebp-4],al
--------------------
标准写法:const char* a = "zhf";。编译器也可接受:char* a = "zhf";,是因为编译器不很规范。
--------------------
参见sunxinvc
-------------------
char* s1="hello";
char s2[]="world";
两个表达式的含义是一样的.
如果讲不同之处的话,VC6中编译时,对这两种定义进行了不同的处理;
char *s1 = "hello"; 中的"hello",编译时指针指向的区域位于PE文件的.rdata节中,是只读的.
不信的话,你可以试试:
main()
{
char *s1="hello";
char s2[]="world";
*(s2+2)='x'; //正确
*(s1+2)='x'; //执行时出错.
}
1.严格的说两个表达的意思是不完全一样的,因为前者是个字符串指针,这个指针S1所存的地址就是存储字符串前8个字节即hello/n/n/n的那个地址。
2.而后者是字符数组。每个字符都有一个独立的地址。
见图示。