您的位置:首页 > 编程语言 > C语言/C++

[C/C++] char[]和char*变量的==比较

2016-05-05 16:33 603 查看

问题描述

C/C++
编程中,如果对char[]和char*对象进行比较,当然一般来说可以使用
strcmp
方法,但是如果直接使用
==
会产生什么结果呢,如下面的程序:

#include <iostream>
using namespace std;
int main() {
char strArray1[] = "abc";
char strArray2[] = "abc";
cout << boolalpha << (strArray1 == strArray2) << endl;

char* strPointer1 = "abc";
char* strPointer2 = "abc";
cout << boolalpha << (strPointer1 == strPointer2 ) << endl;
}


注:
boolalpha
方法是为了以true或者false的方式打印

这个程序很简单,不需要太多的解释。

最后打出的结果可能会感觉应该都是
false
,但是实际的结果是:

第一个打出的是
false
,而第二个打出的是
true


问题分析

那么为什么会有这种结果呢,首先需要知道的是
==
比较的不是指向的内容
abc
,比较的是各个
str
对象中存储的是指向内容的地址,换句话说就是
abc
的地址,是它们本身的存储的值。

Array
对象

Array
对象来说,是运行时在栈空间上分配的内存,所以每个对象都是单独去申请内存,各自保存一份自己的
abc
,所以
Array
对象存储的地址也是不一样的,所以第一个结果是
false


Pointer
对象

Pointer
对象来说,两个字符指针并没有分配相应的存储区,是后面的
abc
是以常量的形式存在常量区,然后把首地址的值赋值给了
Pointer
对象,所以
Pointer
对象存储的地址应该来说是一样的,所以第二个结果是
true


注意事项

其实可以想到通过打印相关的地址来查看结果是否正确,但这里会有个问题:

数组对象

下面直接打印数组对象,其实是打印的数组对象的内容,结果都是
abc


cout << strArray1 << endl;
cout << strArray2 << endl;


对于数组对象可以这样打印数组的首地址,可以从这里看出这两个地址是不同的,即两个
abc
存储在不同的空间

cout << &strArray1 << endl;
cout << &strArray2 << endl;


指针对象

下面直接打印指针对象,其实是打印的也是指针对象的内容,结果都是
abc
,这样打印按道理来说应该是打印的字符串的首地址,是因为对
cout
进行了重载,打印字符指针时,给出地址不是打印地址内容,而是打印相对的字符的内容,所以会得到
abc
结果

cout << strPointer1 << endl;
cout << strPointer2 << endl;


但是如果取该指针的地址来打印的话,结果两个地址是不对的,因为此时打印的不是指向的字符串的首地址了,而是该指针的地址,当然不一样

cout << &strPointer1 << endl;
cout << &strPointer2 << endl;


如果要获取指针对象的字符串的首地址的值的话,需要让
cout
输出符不认为它是一个字符指针,这样就不会产生重载操作了,这样可以看到两个地址是相同的

cout << (void*)strPointer1 << endl;
cout << (void*)strPointer2 << endl;
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: