C++宽字符与普通字符的相互转换方法
来源:互联网 发布:江苏盐城大数据产业园 编辑:程序博客网 时间:2024/04/28 13:36
- //把字符串转换成宽字符串
- wstring string2Wstring(string sToMatch)
- {
- #ifdef _A_WIN
- int iWLen = MultiByteToWideChar( CP_ACP, 0, sToMatch.c_str(), sToMatch.size(), 0, 0 ); // 计算转换后宽字符串的长度。(不包含字符串结束符)
- wchar_t *lpwsz = new wchar_t [iWLen + 1];
- MultiByteToWideChar( CP_ACP, 0, sToMatch.c_str(), sToMatch.size(), lpwsz, iWLen ); // 正式转换。
- lpwsz[iWLen] = L'/0';
- wstring wsToMatch(lpwsz);
- delete []lpwsz;
- #elif _A_LINUX
- setlocale( LC_CTYPE, "" ); // 很重要,没有这一句,转换会失败。
- int iWLen = mbstowcs( NULL, sToMatch.c_str(), sToMatch.length() ); // 计算转换后宽字符串的长度。(不包含字符串结束符)
- wchar_t *lpwsz = new wchar_t[iWLen + 1];
- int i = mbstowcs( lpwsz, sToMatch.c_str(), sToMatch.length() ); // 转换。(转换后的字符串有结束符)
- wstring wsToMatch(lpwsz);
- delete []lpwsz;
- #endif
- return wsToMatch;
- }
- //把宽字符串转换成字符串,输出使用
- string wstring2string(wstring sToMatch)
- {
- #ifdef _A_WIN
- string sResult;
- int iLen = WideCharToMultiByte( CP_ACP, NULL, sToMatch.c_str(), -1, NULL, 0, NULL, FALSE ); // 计算转换后字符串的长度。(包含字符串结束符)
- char *lpsz = new char[iLen];
- WideCharToMultiByte( CP_OEMCP, NULL, sToMatch.c_str(), -1, lpsz, iLen, NULL, FALSE); // 正式转换。
- sResult.assign( lpsz, iLen - 1 ); // 对string对象进行赋值。
- delete []lpsz;
- #elif _A_LINUX
- int iLen = wcstombs( NULL, sToMatch.c_str(), 0 ); // 计算转换后字符串的长度。(不包含字符串结束符)
- char *lpsz = new char[iLen + 1];
- int i = wcstombs( lpsz, sToMatch.c_str(), iLen ); // 转换。(没有结束符)
- lpsz[iLen] = '/0';
- string sResult(lpsz);
- delete []lpsz;
- #endif
- return sResult;
- }
0 0
- C++宽字符与普通字符的相互转换方法
- C++宽字符与普通字符的转换方法
- 普通字符与宽字符的转换
- 宽字符与字符串的相互转换
- 宽字符至多字符的相互转换方法
- 宽字符至多字符的相互转换方法
- 宽字符至多字符的相互转换方法
- 宽字符与ANSI字符之间的相互转换
- 宽字符与ANSI字符之间的相互转换
- c语言中数字与字符之间的相互转换
- 整型与字符型的相互转换
- ascii码与字符的相互转换
- Unicode字符与GB2312的相互转换
- Python字符与数字的相互转换
- Python字符与数字的相互转换
- Unicode字符与GB2312的相互转换
- MBS与Unicode字符的相互转换
- Python字符与数字的相互转换
- 不用struts2的token机制,手动防止表单数据重复提交
- 一些开源的并且有用的工具收集
- LINUx 驱动程序printk 调试
- 验证手机号
- 如何将baidu地图中的baidu logo 去掉
- C++宽字符与普通字符的相互转换方法
- nodejs中处理回调函数的异常
- 【DP】计算一个数组的最长递增子序列
- Android利用canvas画各种图形(点、直线、弧、圆、椭圆、文字、矩形、多边形、曲线、圆角矩形)
- hdu 3371(Connect the Cities)(最小生成树)
- 我还要做好网管(一)
- 再探Objective-C.1
- Android +NDK+eclipse+opengl ES2.0 开启深度测试
- .Net程序员玩转Android开发---(1)环境搭建