标签:c string unicode internationalization
谈到国际化Unicode,我是个白痴的美国程序员.这是交易.
#include <string>
using namespace std;
typedef basic_string<unsigned char> ustring;
int main()
{
static const ustring my_str = "Hello, UTF-8!"; // <== error here
return 0;
}
这发出了意外的投诉:
无法从“ const char [14]”转换为“ std :: basic_string< _Elem>”
也许我今天喝了错误的咖啡.我该如何解决?我能否保留基本结构:
ustring something = {在这里插入魔咒};
?
解决方法:
窄字符串文字被定义为const char,并且没有无符号字符串文字[1],因此您必须进行强制转换:
ustring s = reinterpret_cast<const unsigned char*>("Hello, UTF-8");
当然,您可以将较长的内容放入内联函数中:
inline const unsigned char *uc_str(const char *s){
return reinterpret_cast<const unsigned char*>(s);
}
ustring s = uc_str("Hello, UTF-8");
或者,您可以只使用basic_string< char>并在处理UTF-8时有99.9%的时间摆脱它.
[1]除非char是无符号的,否则是否由实现定义,等等,等等.
标签:c,string,unicode,internationalization 来源: https://codeday.me/bug/20191011/1892486.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。