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

问题描述

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的地址,是它们本身的存储的值。

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

  2. 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;
  • 4
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值