c++-----char*与string

char*
声明存储字符串的数组时,数组大小至少比所存储的字符串多1,因为编译器会自动在
字符串常量的末尾添加空字符\0

例如 char * names3 = “jack”; //jack末尾有\0
char names1[] = { ‘j’, ‘a’, ‘c’, ‘k’, ‘\0’ };
char names2[50] = “ja2ck”;
const char* names3 = “jack”;
//注意由于定义指针指向字符串初始化的,要用const定义,因为这个字符串属于常量,放在常量区,不能被更改

string:
之前在某篇文章中看到,C语言字符串是以’\0’结尾的,但是C++string类型的字符串并不是以’\0’结尾。话不多说,直接放代码(Cygwin64环境g++编译器):

string b("abc");
cout << b.capacity() << endl;
cout << b.size() << endl;

if(b[3] == '\0')
	cout << "yes" << endl;
else
	cout << "no" << endl;

运行结果:

3
3
yes

可以看到,字符串b大小和容量都是3,但是却可以使用b[3]越界访问,并且字符串的结尾就是’\0’。此刻,我心里想"abc"是C语言风格的字符串给b构造,肯定会把"abc"后面影藏的’\0’给构造进去。至于size和capacity是3,是因为这些方法进行了结尾处理,不计算最后一个’\0’,所以都是3。

然后我再试了如下代码:

string a("abcd",3);
cout << a.capacity() << endl;
cout << a.size() << endl;

if(a[3] == '\0')
	cout << "yes" << endl;
else
	cout << "no" << endl;

结果跟上面一模一样。此刻我又想,构造函数会在末尾自动添加一个’\0’,并且size和capacity函数都不计算’\0’的。

所以此刻,我肯定是矛盾的。因为最开始说string字符串是不以’\0’结尾的,但是测试下来,确实是以’\0’结尾的。

经过一番查找,得出:

std::string:标准中未规定需要\0作为字符串结尾。编译器在实现时既可以在结尾加\0,也可以不加。(因编译器不同)

但是,当通过c_str()或data()(二者在 C++11 及以后是等价的)来把std::string转换为const char
*时,会发现最后一个字符是\0。但是C++11,string字符串都是以’\0’结尾。

最后说一下,为什么C语言风格的字符串要以’\0’结尾,C++可以不要:

c语言用char*指针作为字符串时,在读取字符串时需要一个特殊字符0来标记指针的结束位置,也就是通常认为的字符串结束标记。

而c++语言则是面向对象的,长度信息直接被存储在了对象的成员中,读取字符串可以直接根据这个长度来读取,所以就没必要需要结束标记了。而且结束标记也不利于读取字符串中夹杂0字符的字符串。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值