[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;
相关文章推荐
- 【C语言】1-1/2+1/3-1/4……1/n求多项式结果
- c++中字符串的输入
- C++实验5--项目1:数组分离
- c++构造函数 对象初始化
- C++ new的nothrow关键字和new_handler用法
- leetcode笔记:Excel Sheet Column Number
- nyoj17 单调递增最长子序列
- <<Effective C++>> 读书笔记6: 继承与面向对象设计
- C++去除文件名中的空格
- C++ 单链表基本操作分析与实现
- C++命名空间详解
- int 与 string 相互转换
- C++11系列-常量表达式
- C++11系列-区间迭代
- C++11系列-lambda函数
- C++11系列-改进的类型推导:auto、decltype和新的函数语法
- C++11系列-什么是C++11
- c语言中变量作用域的区别
- c++ getline
- C++写入txt文件方法