标签:from 获得 编码 ++ 中国 忽略 color 类型 row
std::string to_string(int value); std::string to_string(long value); std::string to_string(long long value); std::string to_string(unsigned value); std::string to_string(unsigned long value); std::string to_string(unsigned long long value); std::string to_string(float value); std::string to_string(double value); std::string to_string(long double value); std::wstring to_wstring(int value); std::wstring to_wstring(long value); std::wstring to_wstring(long long value); std::wstring to_wstring(unsigned value); std::wstring to_wstring(unsigned long value); std::wstring to_wstring(unsigned long long value); std::wstring to_wstring(float value); std::wstring to_wstring(double value); std::wstring to_wstring(long double value);
std::aoti(const char *):字符串转换为int类型。
std::aotl(const char *):字符串转换为long类型。
std::aotll(const char *):字符串转换为long long类型。
std::aotf(const char *):字符串转换为浮点类型。
如果需要转换的字符串前面部分不是数字,会返回0;如果字符串的前面部分有空格含数字,转换时忽略空格并获得前面的数字。
C++11增加了unicode字面量的支持,可以通过L来定义宽字符。
std::wstring str = L"中国人"; //定义unicode字符串
将宽字符串转换为窄字符串需要用到codecvt库中的std::wstring_convert,不过需要借助以下几个unicode转换器:
std::codocvt_utf8,封装了UTF-8与UCS2及UTF-8与UCS4的编码转换。
std::codocvt_utf16,封装了UTF-16与UCS2及UTF-16与UCS4的编码转换。
std::codocvt_utf8_utf_16,封装了UTF-8与UTF-16的编码转换。
std::wstring_convert使std::string和std::wstring之间的相互转换变得很方便。
#include <string> #include <codecvt> #include <iostream> int main() { std::wstring str = L"中国人"; std::wstring_convert<std::codecvt<wchar_t, char, std::mbstate_t>> converter(new std::codecvt<wchar_t, char, std::mbstate_t>("CHS")); std::string narrowStr = converter.to_bytes(str); //string 转化为wstring std::wstring wstr = converter.from_bytes(narrowStr); std::cout << narrowStr << std::endl; std::wcout.imbue(std::locale("chs")); std::wcout << wstr << std::endl; return 0; } //执行结果 中国人 中国人
标签:from 获得 编码 ++ 中国 忽略 color 类型 row
原文地址:http://www.cnblogs.com/ChinaHook/p/7788921.html