std::wstring UTF8ToUnicode(const std::string& utf8string)

 {
 int widesize = ::MultiByteToWideChar(CP_UTF8, , utf8string.c_str(), -, NULL, );
 if (widesize == ERROR_NO_UNICODE_TRANSLATION)
 {
  throw std::exception("Invalid UTF-8 sequence.");
 }
 if (widesize == )
 {
  throw std::exception("Error in conversion.");
 }
 std::vector<wchar_t> resultstring(widesize);
 int convresult = ::MultiByteToWideChar(CP_UTF8, , utf8string.c_str(), -, &resultstring[], widesize);
 if (convresult != widesize)
 {
  throw std::exception("La falla!");
 }
 return std::wstring(&resultstring[]);
}

std::string WideByteToAcsi(std::wstring& wstrcode)

 {
 int asciisize = ::WideCharToMultiByte(CP_OEMCP, , wstrcode.c_str(), -, NULL, , NULL, NULL);
 if (asciisize == ERROR_NO_UNICODE_TRANSLATION)
 {
  throw std::exception("Invalid UTF-8 sequence.");
 }
 if (asciisize == )
 {
  throw std::exception("Error in conversion.");
 }
 std::vector<char> resultstring(asciisize);
 int convresult = ::WideCharToMultiByte(CP_OEMCP, , wstrcode.c_str(), -, &resultstring[], asciisize, NULL, NULL);
 if (convresult != asciisize)
 {
  throw std::exception("La falla!");
 }
 return std::string(&resultstring[]);
}

std::string UTF8ToASCII(std::string& strUtf8Code)

{
 std::string strRet("");
 //先把 utf8 转为 unicode  
 std::wstring wstr = UTF8ToUnicode(strUtf8Code);
 //最后把 unicode 转为 ascii  
 strRet = WideByteToAcsi(wstr);
 return strRet;
}

std::string ASCIIToUTF8(std::string& strASCIICode)

 {
 std::string strOutUTF8 = "";
 WCHAR * str1;
 int n = MultiByteToWideChar(CP_ACP, , strASCIICode.c_str(), -, NULL, );
 str1 = new WCHAR[n];
 MultiByteToWideChar(CP_ACP, , strASCIICode.c_str(), -, str1, n);
 n = WideCharToMultiByte(CP_UTF8, , str1, -, NULL, , NULL, NULL);
 char * str2 = new char[n];
 WideCharToMultiByte(CP_UTF8, , str1, -, str2, n, NULL, NULL);
 strOutUTF8 = str2;
 delete[]str1;
 str1 = NULL;
 delete[]str2;
 str2 = NULL;
 return strOutUTF8;
}

//!!为了减少字符串的拷贝,改为使用shared_array,性能升级

#include <boost/shared_array.hpp>

#define CHAR_EMPTY_ARR_PTR boost::shared_array<char>(new char[1]{'\0'})
#define WCHAR_EMPTY_ARR_PTR boost::shared_array<wchar_t>(new wchar_t[1]{L'\0'})

boost::shared_array<char> UTF8ToASCII(std::string& strUtf8Code)

 {
 return std::move(UTF8ToASCII(strUtf8Code.c_str()));
}

boost::shared_array<char> UTF8ToASCII(const char* ch, int nLen /*= -1*/)

 {
 //先把 utf8 转为 unicode  
 auto wstr = UTF8ToUnicode(ch, nLen);
 //最后把 unicode 转为 ascii  
 return std::move(WideByteToAcsi(wstr.get()));
}

boost::shared_array<char> ASCIIToUTF8(std::string& strASCIICode)

 {
 return std::move(ASCIIToUTF8(strASCIICode.c_str()));
}

boost::shared_array<char> ASCIIToUTF8(const char* ch, int nLen/* = -1*/)

 {
 int n = MultiByteToWideChar(CP_ACP, , ch, nLen, NULL, );
 if ( == n)
 {
  return CHAR_EMPTY_ARR_PTR;
 }
 boost::shared_array<wchar_t> ptrWtArr(new wchar_t[n]{ L'\0' });
 if ( == MultiByteToWideChar(CP_ACP, , ch, nLen, ptrWtArr.get(), n))
 {
  return CHAR_EMPTY_ARR_PTR;
 }
 n = WideCharToMultiByte(CP_UTF8, , ptrWtArr.get(), -, NULL, , NULL, NULL);
 if ( == n)
 {
  return CHAR_EMPTY_ARR_PTR;
 }
 boost::shared_array<char> ptrArr(new char[n]{ '\0' });
 if ( == WideCharToMultiByte(CP_UTF8, , ptrWtArr.get(), -, ptrArr.get(), n, NULL, NULL))
 {
  return CHAR_EMPTY_ARR_PTR;
 }
 return std::move(ptrArr);
}

boost::shared_array<wchar_t> UTF8ToUnicode(const char* ch, int nLen /*= -1*/)

 {
 int widesize = ::MultiByteToWideChar(CP_UTF8, , ch, nLen, NULL, );
 if ( == widesize)
 {
  return WCHAR_EMPTY_ARR_PTR;
 }
 boost::shared_array<wchar_t> ptrWtArr(new wchar_t[widesize]{ L'\0' });
 int convresult = ::MultiByteToWideChar(CP_UTF8, , ch, nLen, ptrWtArr.get(), widesize);
 if ( == convresult)
 {
  return WCHAR_EMPTY_ARR_PTR;
 }
 return std::move(ptrWtArr);
}
boost::shared_array<char> DPC::WideByteToAcsi(std::wstring& wstrcode)
{
 return std::move(WideByteToAcsi(wstrcode.c_str()));
}

boost::shared_array<char> WideByteToAcsi(const wchar_t* wch, int nLen /*= -1*/)

 {
 int asciisize = ::WideCharToMultiByte(CP_OEMCP, , wch, nLen, NULL, , NULL, NULL);
 if ( == asciisize)
 {
  return CHAR_EMPTY_ARR_PTR;
 }
 boost::shared_array<char> ptrArr(new char[asciisize + ]{'\0'});
 int convresult = ::WideCharToMultiByte(CP_OEMCP, , wch, nLen, ptrArr.get(), asciisize, NULL, NULL);
 if ( == convresult)
 {
  return CHAR_EMPTY_ARR_PTR;
 }
 return std::move(ptrArr);
}

mfc字符转码的更多相关文章

  1. native2ascii.exe 字符转码与反转码

    本人最近在做OAF的二次开发,在看别人写的代码时,发现总有类似这样的语句:”\u65e0\u6548\u7684GP\u9879\u76ee\u7f16\u53f7“,这些语句其实是用Java_hom ...

  2. C#编程总结(十)字符转码

    C#编程总结(十)字符转码 为了适应某种特殊需要,字符需要根据规则进行转码,便于传输.展现以及其他操作等. 看看下面的转码,就知道他的用处了. 1.字符串转码 根据原编码格式与目标编码格式,完成转换. ...

  3. 【jquery】字符ascii码转换函数

    js 字符ascii码转换函数 字符转ascii码:用charCodeAt();ascii码砖字符:用fromCharCode(); 看一个小例子 <script> str="A ...

  4. 关于htmlspecialchars实体字符转码的问题

    php对post过来的数据进行实体字符转码,我的页面编码是gb2312,刚开始是这样: $post = htmlspecialchars ( $post); 取到的$post值为空,但是有时候是好的( ...

  5. python:字符串转换成字节的三种方式及字符转码问题

    str='zifuchuang' 第一种 b'zifuchuang'第二种bytes('zifuchuang',encoding='utf-8')第三种('zifuchuang').encode('u ...

  6. Go url编码和字符转码

    类似php中的urlencode 和htmlspecialchars: package main import ( "fmt" "html" "net ...

  7. String中文字符转码

    如何使用String构造方法和String.getBytes()做好中文字符转码 @Test public void test() { String testStr = "中"; ...

  8. C#编程总结 字符转码

    为了适应某种特殊需要,字符需要根据规则进行转码,便于传输.展现以及其他操作等. 看看下面的转码,就知道他的用处了. 1.字符串转码 根据原编码格式与目标编码格式,完成转换.不过可能出现乱码哦.上一章已 ...

  9. MFC基础类源码CPP实现文件

    WinMain.CPP---->AfxWinMain()  //近似可认为是WinMain()函数的入口 VIEWCORE.CPP---->CView DOCCORE.CPP----> ...

随机推荐

  1. java动态代理之CGLIB实现

    动态代理(CGlib 与连接池的案例) Cglib代理: 针对类来实现代理,对指定目标 产生一个子类 通过方法拦截技术拦截所有父类方法的调用. 我们要使用cglib代理必须引入 cglib的jar包 ...

  2. charles 访问控制设置

    本文参考:charles 访问控制设置 charles 访问控制设置 access control settings 访问账户设置: 这里可以配置连接到charles时的一些配置: 这个访问控制确定谁 ...

  3. React + TypeScript 默认 Props 的处理

    React 中的默认 Props 通过组件的 defaultProps 属性可为其 Props 指定默认值. 以下示例来自 React 官方文档 - Default Prop Values: clas ...

  4. Hadoop 之 分布式缓存的原理和方法——DistributedCache

    1.什么时Hadoop的分布式缓存 答:在执行MapReduce时,可能Mapper之间需要共享一些信息,如果信息量不大,可以将其从HDFS中加载到内存中,这就是Hadoop分布式缓存机制. 2.如何 ...

  5. C++基础之顺序容器

    顺序容器简介: 顺序容器类型 描述 vector 可变大小数组,支持快速访问,在尾部之外的地方插入或删除时可能很慢 deque 双端队列.支持快速访问,在头尾插入删除会很快. list 双向列表.只支 ...

  6. JavaScript之操作符

    计算机被发明的初衷仅仅是为了快速实现一些数学计算,然而经过多年发展,计算机已经不单单能实现快速计算这么简单的工作了,现代计算机不仅能够进行数值的计算,还能进行逻辑计算,还具备存储记忆功能,是能够按照程 ...

  7. Centos 7 配置tomcat服务器

    1.首先查看当前系统版本 uname -a 2.安装之前查看系统是否安装了java rpm -qa |grep java rpm -qa |grep jdk rpm -qa |grep gcj 如果没 ...

  8. jedis 2.9版本部分属性变更

    1.控制一个pool可分配多少个jedis实例 “maxActive” -> “maxTotal” 2.最大建立连接等待时间.如果超过此时间将接到异常.设为-1表示无限制. “maxWait” ...

  9. 根据vue-cli手摸手实现一个自己的脚手架

    故事背景 身为一个入门前端七个月的小菜鸡,在我入门前端的第一天就接触到了vue,并且死皮赖脸的跟他打了这么久的交到,还记得第一次用vue init webpack 这句命令一下生成一个模板的时候那种心 ...

  10. Disruptor—核心概念及体验

    本文基于最新的3.4.2的版本文档进行翻译,翻译自: https://github.com/LMAX-Exchange/disruptor/wiki/Introduction https://gith ...