本文主要是介绍C++字符串(char/string/wchar_t/char16_t/char32_t),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
示例:字符串abc转换成ab6
char name[] = "abc";
name[2]=char(6+48);//48是ascii表中,char和int看起来相等的差值
C++中有五种方式可以表示字符串,记住前两种就可以
1.char类型的数组(C语言风格字符串)
2.string类(C++时代诞生的新类)
3.wchar_t宽字节型变量
4.char16_t
5.char32_t
1.可以使用下面的编码来用char数组表示字符串
char c1[] = {'L','O','L'};char c2[] = {"LOL"};char c3[] = "英雄联盟LOL";const char* c4 = "MEIMEI";std::cout << sizeof(c1) << "\n";//3std::cout << sizeof(c2) << "\n";//4std::cout << sizeof(c3) << "\n";//12std::cout << c4 << "\n";
其中c2打印出4,是因为最后还有一个字符"\0"在隐身,我们看不见
其中c3打印出12,也是相同的原因,4个中文占8个字节,3个英文占3个字节,加一起是11,再加1个最后隐身的"\0",正好12,所以用char数组来表示字符串一定要注意长度的问题
2.string型字符串,关于string类的详细介绍请点击这里
因为string类存在于std命名空间,要想使用string类,则必须添加头文件string并且声明std,像下面这样
#include <string>
using namespace std;
int main()
{string c4 = "约德尔人";
}
或者
#include <string>
int main()
{std::string c4 = "约德尔人";
}
3.wchar_t宽字节型变量
char是1个字节,不能用来保存中文,为了解决这个问题,c++提供了宽字节变量wchar_t,使用方式如下,在不同的系统占字节不一样,不常用,如果执行utf16标准,则占用2个字节,如果执行utf32标准则占用4个字节
#include "pch.h"
#include <iostream>
#include <locale>
int main()
{//必须引用头文件locale,然后调用setlocale方法setlocale(LC_ALL,"chs");//之后才可以定义中文,注意下面是单引号wchar_t aa = L'表';//cout没有实现对wchar_t的支持,所以用cout是不行的,需要用wcoutstd::wcout << aa;
}
上述wchar_t也可以同时放入多个汉字,这个时候写法如下
// aa变成了数组,而之前的单引号也变成了双引号
wchar_t aa[] = L"表妹";
4.char16_t
由于wchar_t在不同系统环境字节数不一样,所以为了统一,出现了char16_t类型,其中16表示16个bit,也就是2字节
注意:在char16下,英文也占2字节,不要认为英文占1个
// char16_t定义的变量需要在前面加小写u
char16_t aa = u'呵';
std::wcout << aa;
std::cout << aa;
通过打印发现,无论是cout还是wout,打印的都是数字,而不是中文,因为c++中没有实现对char16_t的输出,所以该类型无法在屏幕上显示中文
5.char32_t
占四个字节,其他特性与char16_t一样
注意:在char32下,英文也占4字节,不要认为英文占1个
// char32_t定义的变量需要在前面加大写U
char16_t aa = U'呵';
std::wcout << aa;
std::cout << aa;
这篇关于C++字符串(char/string/wchar_t/char16_t/char32_t)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!