千家信息网

C++中的英文字符串基本概念

发表于:2024-12-13 作者:千家信息网编辑
千家信息网最后更新 2024年12月13日,这篇文章主要讲解了"C++中的英文字符串基本概念",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"C++中的英文字符串基本概念"吧!在C++中英文字符串类
千家信息网最后更新 2024年12月13日C++中的英文字符串基本概念

这篇文章主要讲解了"C++中的英文字符串基本概念",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"C++中的英文字符串基本概念"吧!

在C++中英文字符串类的string的模板原型是basic_string

  1. template < class _Elem, class traits = char_traits< _Elem>,
    class _Ax = allocator< _Elem>>

  2. class basic_string{};

***个参数_Elem表示类型。第二个参数traits的缺省值使用char_traits类型,定义了类型和字符操作的函数,如比较、等价、分配等。第三个参数_Ax的默认值是allocator类,表示了内存模式,不同的内存结构将操作指针的不同行为,例如栈、堆或段内存模式等。

在C++标准里定义了两个字符串string和wstring

typedef basic_string< char> string;  typedef basic_string< wchar_t> wstring;

前者string是常用类型,可以看作char[],其实这正是与string定义中的_Elem=char相一致。而wstring,使用的是wchar_t类型,这是宽字符,用于满足非ASCII字符的要求,例如Unicode编码,中文,日文,韩文什么的。对于wchar_t类型,实际上C++中都用与char函数相对应的wchar_t的函数,因为他们都是从同一个模板类似于上面的方式定义的。因此也有wcout, wcin, werr等函数。

实际上string也可以使用中文,但是它将一个汉字写在2个char中。而如果将一个汉字看作一个单位wchar_t的话,那么在wstring中就只占用一个单元,其它的非英文文字和编码也是如此。这样才真正的满足字符串操作的要求,尤其是国际化等工作。

看一下下面的程序,就会理解C++中英文字符串之间的差别。

  1. #include < iostream>

  2. #include < string>

  3. using namespace std;

  4. #define tab "\t"

  5. int main()

  6. {

  7. locale def;

  8. cout< < def.name()< < endl;

  9. locale current = cout.getloc();

  10. cout< < current.name()< < endl;

  11. float val=1234.56;

  12. cout< < val< < endl;

  13. //chage to french/france

  14. cout.imbue(locale("chs"));

  15. current=cout.getloc();

  16. cout< < current.name()< < endl;

  17. cout< < val< < endl;

  18. //上面是说明locale的用法,下面才是本例的内容,因为其中用到了imbue函数

  19. cout< < "*********************************"< < endl;

  20. //为了保证本地化输出(文字/时间/货币等),
    chs表示中国,wcout必须使用本地化解析编码

  21. wcout.imbue(std::locale("chs"));

  22. //string 英文,正确颠倒位置,显示第二个字符正确

  23. string str1("ABCabc");

  24. string str11(str1.rbegin(),str1.rend());

  25. cout< < "UK\ts1\t:"< < str1< < tab< < str1[1]< <
    tab< < str11< < endl;

  26. //wstring 英文,正确颠倒位置,显示第二个字符正确

  27. wstring str2=L"ABCabc";

  28. wstring str22(str2.rbegin(),str2.rend());

  29. wcout< < "UK\tws4\t:"< < str2< < tab< < str2[1]
    < < tab< < str22< < endl;

  30. //string 中文,颠倒后,变成乱码,第二个字符读取也错误

  31. string str3("你好么?");

  32. string str33(str3.rbegin(),str3.rend());

  33. cout< < "CHN\ts3\t:"< < str3< < tab< < str3[1]
    < < tab< < str33< < endl;

  34. //正确的打印第二个字符的方法

  35. cout< < "CHN\ts3\t:RIGHT\t"< < str3[2]< < str3[3]< < endl;

  36. //中文,正确颠倒位置,显示第二个字符正确

  37. wstring str4=L"你好么?";

  38. wstring str44(str4.rbegin(),str4.rend());

  39. wcout< < "CHN\tws4\t:"< < str4< < tab< < str4[1]

    < < tab< < str44< < endl;

  40. wstring str5(str1.begin(),str1.end());
    //只有char类型的string时才可以如此构造

  41. wstring str55(str5.rbegin(),str5.rend());

  42. wcout< < "CHN\tws5\t:"< < str5< < tab< <
    str5[1]< < tab< < str55< < endl;

  43. wstring str6(str3.begin(),str3.end());//如此构造将失败!!!!

  44. wstring str66(str6.rbegin(),str6.rend());

  45. wcout< < "CHN\tws6\t:"< < str6< < tab< <
    str6[1]< < tab< < str66< < endl;

  46. return 0;

  47. }

感谢各位的阅读,以上就是"C++中的英文字符串基本概念"的内容了,经过本文的学习后,相信大家对C++中的英文字符串基本概念这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是,小编将为大家推送更多相关知识点的文章,欢迎关注!

0