两者不相等,是因为str1 和 str2 都是字符数组,每个都有其自己的存储区,它们的值则是各存储区的首地址。但有些情况却不一样,
程序如下:
#include <stdio.h>
int main(void)
{
const char str3[] = "abc";
const char str4[] = "abc";
const char *str5 = "abc";
const char *str6 = "abc";
printf("str3 = %d\n",str3);
printf("str4 = %d\n",str4);
printf("str5 = %d\n",str5);
printf("str6 = %d\n",str6);
if(str3 == str4)
printf("Hello1 World!\n");
else
printf("str3[] = 'abc'与 str4[] = 'abc' 不相等!\n");
if(str5 == str6)
printf("*str5 = ‘abc’ 与 *str6 = ‘abc’ 相等!\n");
else
printf("*str5 = ‘abc’ 与 *str6 = ‘abc’ 不相等!\n");
return 0;
}
输出结果
str3 = 905867392
str4 = 905867408
str5 = 4196168
str6 = 4196168
str3[] = 'abc'与 str4[] = 'abc' 不相等!
*str5 = ‘abc’ 与 *str6 = ‘abc’ 相等!
因为str3和str4两个字符数组都存储在栈空间上,但两者地址值不相等。而str5 和str6并非字符数组而是字符指针,并不分配存储区,其后的“abc”以常量形式存于常量区,str5 和 str6 是指它们指向的地址的首地址,而它们自己仅是指向该区首地址的指针,所以相等(&str5 和 &str6 是指指针自己的地址,所以两者地址是不相等的)。
str1和str2 是在堆栈中定义的一段内存 这是两个东西 所以是不同的地方
p1 和 p2 是编译器吧或者什么你不知道的东西在一个神秘的地方开辟了一个空间放了 abc\0
而p1 和p2 这样定义的东西是不能修改的所以编译器或者什么东西看到 p2定义的时候发现 嘿!我见过它
然后就把p1 那个地方的abc 中a的地址给了 p2
char str1[] 和char *p 这两者分配的地址位置不一样
一个在栈上,一个在常量区
p1,p2相同----编译器的优化
const char str1[] = "abc";
const char str2[] = "abc";
这是在栈上分配的 从高地址到低地址分配 当然不相等
而const char *p1 = "abc";
const char *p2 = "abc";
这两个指针指向的是同一地址 编译器认为p1指向的“abc”和p2指向的“abc”是属于同一常量 很多书上都有这个提示
char str1[] 和char *p 这两者分配的地址位置不一样
一个在栈上,一个在常量区
p1,p2相同----编译器的优化