本篇内容主要讲解“C++的char[]和char*变量有什么不同”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“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
的地址,是它们本身的存储的值。
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++的char[]和char*变量有什么不同”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。