今天看华为的软件笔试题目时,遇见了这样一道题目:
char str1[] = "abc";
char str2[] = "abc";
const char str3[] = "abc";
const char str4[] = "abc";
const char *str5 = "abc";
const char *str6 = "abc";
char *str7 = "abc";
char *str8 = "abc";
cout < < ( str1 == str2 ) < < endl;
cout < < ( str3 == str4 ) < < endl;
cout < < ( str5 == str6 ) < < endl;
cout < < ( str7 == str8 ) < < endl;
答案:0,0,1,1
我的理解是:数组在内存中开辟一个空间,它保存的是字符串常量本身,指针在内存中也需要先开辟一个内存来存放指针,指针的值是它所指对象的地址,在这里,指针的值是字符串常量的地址。编译器优化了相同的常量,在内存中只保存一份,所以,只要是字符串常量不变,那么它在内存中的地址就唯一,指向它的指针的值就唯一。具体解释如下:
问题:
如果改为:
则运行正确,百思不得其解后,通过一上午的查阅资料,终于找到答案。
我做了一个测试程序,截了一个图,答案都在下面:
答案已经全部在图上。
总结:
1. char * p = “hello”;//是在编译时就要确定字符串的内容。
char q[] = “hello”;//在运行时确定字符串的内容
其中,p存放的是字符串的地址,q存放的是字符串本身。所以p已经初始化之后,就不能修改。
就速度而言,显然第二种方式比第一种快。
2.C语言程序内存分配,有下列几个区:
像char * p = “hello”; 这种方式定义的字符串就是放在文字常量区的。所以定义后是不能修改的。
编程过程中,遇到这样一个问题,于是求教别人,自己又查阅了一些资料。先总结一下。
问题:
如果改为:
则运行正确,百思不得其解后,通过一上午的查阅资料,终于找到答案。
我做了一个测试程序,截了一个图,答案都在下面:
答案已经全部在图上。
总结:
1. char * p = “hello”;//是在编译时就要确定字符串的内容。
char q[] = “hello”;//在运行时确定字符串的内容
其中,p存放的是字符串的地址,q存放的是字符串本身。所以p已经初始化之后,就不能修改。
就速度而言,显然第二种方式比第一种快。
2.C语言程序内存分配,有下列几个区:
像char * p = “hello”; 这种方式定义的字符串就是放在文字常量区的。所以定义后是不能修改的。