C++实现编码转换的示例代码

 更新时间:2020年08月14日 11:45:59   作者:gongluck  
这篇文章主要介绍了C++实现编码转换的示例代码,帮助大家快捷的实现编码转换,感兴趣的朋友可以了解下

代码地址

https://github.com/gongluck/Code-snippet/tree/master/cpp/code%20conversion

需求

编码转换在实际开发中经常遇到,通常是ANSI、Unicode和Utf-8之间相互转换。实现也有很多种,有查表法、使用C++11、使用boost、使用系统API。C++11和boost几乎可以实现一套代码,在linux和windows都能使用,但实际会有很多坑,相当于代码几乎不改,但是要改一下系统环境。所以有一种实现就是判断系统的版本,然后选择不同的系统api进行编码转换。

实现

目前只实现Windows下的编码转换,以后需要在linux下使用编码转换再做补充。windows下的编码转换基本围绕unicode做处理。例如ANSI->UTF-8,就是先将ANSI->unicode,再将unicode->UTF-8。

// convert.h
/*
 * @Author: gongluck 
 * @Date: 2020-03-23 16:06:23 
 * @Last Modified by: gongluck
 * @Last Modified time: 2020-03-23 16:09:30
 */

// Character encoding conversion

#pragma once

#include <string>

namespace gconvert
{
// ANSI->Unicode
int ansi2uni(const std::string& ansi, std::wstring& uni);

// Unicode->ANSI
int uni2ansi(const std::wstring& uni, std::string& ansi);

// UTF8->Unicode
int utf82uni(const std::string& utf8, std::wstring& uni);

// Unicode->UTF8
int uni2utf8(const std::wstring& uni, std::string& utf8);

// ANSI->UTF8
int ansi2utf8(const std::string& ansi, std::string& utf8);

// UTF8->ANSI
int utf82ansi(const std::string& utf8, std::string& ansi);
} // namespace gconvert
//convert.cpp
/*
 * @Author: gongluck 
 * @Date: 2020-03-23 16:13:01 
 * @Last Modified by: gongluck
 * @Last Modified time: 2020-03-23 16:34:50
 */

#include "convert.h"

#include <iostream>

#ifdef _WIN32
#include <windows.h>
#endif

namespace gconvert
{
#ifdef _WIN32
 static int multi2uni(const std::string& multi, std::wstring& uni, UINT code)
 {
  auto len = MultiByteToWideChar(code, 0, multi.c_str(), -1, nullptr, 0);
  if (len <= 0)
  {
   std::cerr << __FILE__ << " : " << __LINE__ << " : " << GetLastError() << std::endl;
   return -1;
  }
  WCHAR* buf = new WCHAR[len];
  if (buf == nullptr)
  {
   std::cerr << __FILE__ << " : " << __LINE__ << " : " << "can not new buf, size : " << len << std::endl;
   return -2;
  }
  len = MultiByteToWideChar(code, 0, multi.c_str(), -1, buf, len);
  uni.assign(buf);
  delete[]buf;
  buf = nullptr;
  return len;
 }

 static int uni2multi(const std::wstring& uni, std::string& multi, UINT code)
 {
  auto len = WideCharToMultiByte(code, 0, uni.c_str(), -1, nullptr, 0, nullptr, nullptr);
  if (len <= 0)
  {
   std::cerr << __FILE__ << " : " << __LINE__ << " : " << GetLastError() << std::endl;
   return -1;
  }
  CHAR* buf = new CHAR[len];
  if (buf == nullptr)
  {
   std::cerr << __FILE__ << " : " << __LINE__ << " : " << "can not new buf, size : " << len << std::endl;
   return -2;
  }
  len = WideCharToMultiByte(code, 0, uni.c_str(), -1, buf, len, nullptr, nullptr);
  multi.assign(buf);
  delete[]buf;
  buf = nullptr;
  return len;
 }
#endif

// ANSI->Unicode
int ansi2uni(const std::string& ansi, std::wstring& uni)
{
#ifdef _WIN32
 return multi2uni(ansi, uni, CP_ACP);
#endif
 return 0;
}

// Unicode->ANSI
int uni2ansi(const std::wstring &uni, std::string &ansi)
{
#ifdef _WIN32
 return uni2multi(uni, ansi, CP_ACP);
#endif
 return 0;
}

// UTF8->Unicode
int utf82uni(const std::string& utf8, std::wstring& uni)
{
#ifdef _WIN32
 return multi2uni(utf8, uni, CP_UTF8);
#endif
 return 0;
}

// Unicode->UTF8
int uni2utf8(const std::wstring& uni, std::string& utf8)
{
#ifdef _WIN32
 return uni2multi(uni, utf8, CP_UTF8);
#endif
 return 0;
}

// ANSI->UTF8
int ansi2utf8(const std::string &ansi, std::string &utf8)
{
 std::wstring uni;
 auto len = ansi2uni(ansi, uni);
 if (len <= 0)
 {
  return -3;
 }
 return uni2utf8(uni, utf8);
}

// UTF8->ANSI
int utf82ansi(const std::string &utf8, std::string &ansi)
{
 std::wstring uni;
 auto len = utf82uni(utf8, uni);
 if (len <= 0)
 {
  return -3;
 }
 return uni2ansi(uni, ansi);
}
} // namespace gconvert
//testcode
#include <iostream>

#include "../code conversion/convert.h"

int main()
{
 std::string ansi = "你好,世界!";
 std::wstring uni;
 std::string utf8;
 ret = gconvert::ansi2uni(ansi, uni);
 ret = gconvert::ansi2utf8(ansi, utf8);
 ret = gconvert::uni2ansi(uni, ansi);
 ret = gconvert::uni2utf8(uni, utf8);
 ret = gconvert::utf82ansi(utf8, ansi);
 ret = gconvert::utf82uni(utf8, uni);
 return 0;
}

以上就是C++实现编码转换的示例代码的详细内容,更多关于C++实现编码转换的资料请关注脚本之家其它相关文章!

相关文章

  • C++ 私有析构函数的作用示例详解

    C++ 私有析构函数的作用示例详解

    这篇文章主要介绍了C++ 私有析构函数的作用,私有析构函数不会影响栈上对象的自动析构,它们会在其作用域结束时自动调用析构函数。私有析构函数主要影响的是对堆上对象的显式删除操作,需要的朋友可以参考下
    2023-06-06
  • 利用C语言编写一个无限循环语句

    利用C语言编写一个无限循环语句

    这篇文章主要介绍了利用C语言编写一个无限循环语句问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-11-11
  • C++之关于string对象的大小比较

    C++之关于string对象的大小比较

    这篇文章主要介绍了C++之关于string对象的大小比较方式,具有很好的 参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-11-11
  • C语言实现二叉树遍历的迭代算法

    C语言实现二叉树遍历的迭代算法

    这篇文章主要介绍了C语言实现二叉树遍历的迭代算法,包括二叉树的中序遍历、先序遍历及后序遍历等,是非常经典的算法,需要的朋友可以参考下
    2014-09-09
  • C++实现连连看游戏核心代码

    C++实现连连看游戏核心代码

    这篇文章主要为大家详细介绍了C++实现连连看游戏核心代码,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-01-01
  • C++实现关系与关系矩阵的代码详解

    C++实现关系与关系矩阵的代码详解

    这篇文章主要介绍了C++实现关系与关系矩阵,功能实现包括关系的矩阵表示,关系的性质判断及关系的合成,本文结合示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-04-04
  • C语言开发中的常见错误详解

    C语言开发中的常见错误详解

    这个分栏是对于使用C语言编程过程中可能会出现的一些错误而进行的说明,更多的错误示例将会在后面的内容里进行演示。希望这个分栏的内容可以帮助刚学编程的小白少走一些弯路,以及吸取更多的编码经验
    2022-05-05
  • C语言数据结构之双链表&循环链表&静态链表详解

    C语言数据结构之双链表&循环链表&静态链表详解

    这篇文章主要为大家详细介绍了C语言数据结构中双链表&循环链表&静态链表的原理与使用,文中的示例代码讲解详细,感兴趣的可以了解一下
    2022-09-09
  • C++中简单的文本文件输入/输出示例详解

    C++中简单的文本文件输入/输出示例详解

    C++程序把输入和输出看作字节流,输入时程序从输入流中抽取字节,输出时程序将字节插入到输出流中,下面这篇文章主要给大家介绍了关于C++中简单的文本文件输入/输出的相关资料,需要的朋友可以参考下
    2021-12-12
  • c++中for双循环的那些事

    c++中for双循环的那些事

    本人很菜,今天看《C++编程思想》中的一道课后题中说到这样一个问题。修改两层嵌套的for循环的标识符,观察结果变化
    2013-05-05

最新评论