大家好,欢迎来到IT知识分享网。
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];
00A4DF1movcl,byteptr[ebp-0Fh]
0040106A884DFCmovbyteptr[ebp-4],cl
11:a=p[1];
0040106D8B55ECmovedx,dwordptr[ebp-14h]
00A4201moval,byteptr[edx+1]
00FCmovbyteptr[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.而后者是字符数组。每个字符都有一个独立的地址。
见图示。
免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://haidsoft.com/148233.html