C++实现字符格式相互转换的示例代码

 更新时间:2022年11月15日 11:20:19   作者:欧特克_Glodon  
这篇文章主要为大家详细介绍了C++中实现字符格式相互转换的方法,主要有UTF8与string互转、wstring与string互转,感兴趣的小伙伴可以了解一下

一、UTF8转std:string

std::string UTF8_To_string(const std::string& str)
{
	int nwLen = MultiByteToWideChar(CP_UTF8, 0, str.c_str(), -1, NULL, 0);
	wchar_t* pwBuf = new wchar_t[nwLen + 1];    //一定要加1,不然会出现尾巴 
	memset(pwBuf, 0, nwLen * 2 + 2);
	MultiByteToWideChar(CP_UTF8, 0, str.c_str(), str.length(), pwBuf, nwLen);
	int nLen = WideCharToMultiByte(CP_ACP, 0, pwBuf, -1, NULL, NULL, NULL, NULL);
	char* pBuf = new char[nLen + 1];
	memset(pBuf, 0, nLen + 1);
	WideCharToMultiByte(CP_ACP, 0, pwBuf, nwLen, pBuf, nLen, NULL, NULL);

	std::string strRet = pBuf;

	delete[]pBuf;
	delete[]pwBuf;
	pBuf = NULL;
	pwBuf = NULL;

	return strRet;
}

二、string_To_UTF8

std::string string_To_UTF8(const std::string& str)
{
	int nwLen = ::MultiByteToWideChar(CP_ACP, 0, str.c_str(), -1, NULL, 0);
	wchar_t* pwBuf = new wchar_t[nwLen + 1];    //一定要加1,不然会出现尾巴 
	ZeroMemory(pwBuf, nwLen * 2 + 2);
	::MultiByteToWideChar(CP_ACP, 0, str.c_str(), str.length(), pwBuf, nwLen);
	int nLen = ::WideCharToMultiByte(CP_UTF8, 0, pwBuf, -1, NULL, NULL, NULL, NULL);
	char* pBuf = new char[nLen + 1];
	ZeroMemory(pBuf, nLen + 1);
	::WideCharToMultiByte(CP_UTF8, 0, pwBuf, nwLen, pBuf, nLen, NULL, NULL);

	std::string strRet(pBuf);

	delete[]pwBuf;
	delete[]pBuf;
	pwBuf = NULL;
	pBuf = NULL;

	return strRet;
}

三、wstring转string

std::string wstring2string(std::wstring wstr)
{
	string result;
	int len = WideCharToMultiByte(CP_ACP, 0, wstr.c_str(), wstr.size(), NULL, 0, NULL, NULL);
	if (len <= 0)return result;
	char* buffer = new char[len + 1];
	if (buffer == NULL)return result;
	WideCharToMultiByte(CP_ACP, 0, wstr.c_str(), wstr.size(), buffer, len, NULL, NULL);
	buffer[len] = '\0';
	result.append(buffer);
	delete[] buffer;
	return result;
}

四、string转wstring

std::wstring  string2wstring(std::string str)
{
	wstring result;
	int len = MultiByteToWideChar(CP_ACP, 0, str.c_str(), str.size(), NULL, 0);
	if (len < 0)return result;
	wchar_t* buffer = new wchar_t[len + 1];
	if (buffer == NULL)return result;
	MultiByteToWideChar(CP_ACP, 0, str.c_str(), str.size(), buffer, len);
	buffer[len] = '\0';
	result.append(buffer);
	delete[] buffer;
	return result;
}

五、unicode属性和多字节属性转换(char转wchar_t)

// WideChar.cpp : 定义控制台应用程序的入口点。
//

#include "stdafx.h"

#include <windows.h>
#include <iostream>
#include <atlbase.h>
//#include <comutil.h>
#include <atlstr.h>
using namespace std;

//方法1:MultiByteToWideChar, WideCharToMultiByte
void Way_1()
{
	//char转wchar_t
	char *p1 = "abc";
	wchar_t p2[20] = L"EFG";
	MultiByteToWideChar(CP_ACP, 0, p1, strlen(p1) + 1, p2, sizeof(p2));
	printf("%S\n", p2);

	//wchar_t转char
	wchar_t *p3= L"EFG";
	char p4[20];
	WideCharToMultiByte(CP_ACP, 0, p3, -1, p4, sizeof(p4), NULL, NULL);
	printf("%s\n", p4);

}

//方法2:A2W, W2A, T2A, A2T
void Way_2()
{
	//需要添加头文件 <atlbase.h>
	char * p1 = "abc";
	wchar_t *p2 = L"def";
	TCHAR *P3 = _T("CC");

	USES_CONVERSION;
	wchar_t *p5 = A2W(p1);
	char * p4 = T2A(P3);
}

方法3:
//void Way_3()
//{//需要添加头文件<comutil.h>,一般在MFC工程下使用
//	CString str = "abc";//只能存一种
//	_bstr_t bstr = "abc";//可以用非unicode
//	bstr += L"efg";//可以用unicode
//	char *p = bstr;
//	wchar_t *p2 = bstr;
//}

int main()
{
	Way_1();
	//Way_2();

	return 0;
}

六、Unicode ansi utf8转换

int Unicode2UTF8(const wchar_t* pUnicode, char* pUTF8Buffer, int nBufferSize)
{
	if( (nBufferSize == 0) && (pUTF8Buffer != NULL) )
		return 0;

	int result = WideCharToMultiByte(CP_UTF8, NULL, pUnicode, -1, pUTF8Buffer, nBufferSize, NULL, NULL);
	if ((result > 0) && (pUTF8Buffer != NULL))
		pUTF8Buffer[result-1] = 0;

	return result;
}

int UTF82Unicode(const char* pUTF8, wchar_t* pUnicodeBuffer, int nBufferSize)
{
	if( (nBufferSize == 0) && (pUnicodeBuffer != NULL) )
		return 0;

	int result = MultiByteToWideChar(CP_UTF8, NULL, pUTF8, -1, pUnicodeBuffer, nBufferSize);
	if ((result > 0) && (pUnicodeBuffer != NULL))
		pUnicodeBuffer[result-1] = 0;

	return result;
}

int Unicode2Ansi(const wchar_t* pUnicode, char* pAnsiBuffer, int nBufferSize)
{
	if( (nBufferSize == 0) && (pAnsiBuffer != NULL) )
		return 0;

	int result = ::WideCharToMultiByte(CP_ACP, 0, pUnicode, -1, pAnsiBuffer, nBufferSize, NULL, NULL);
	if ((result > 0) && (pAnsiBuffer != NULL))
		pAnsiBuffer[result-1] = 0;

	return result;
}

int Ansi2Unicode(const char* pAnsi, wchar_t* pUnicodeBuffer, int nBufferSize)
{
	if( (nBufferSize == 0) && (pUnicodeBuffer != NULL) )
		return 0;

	int result = ::MultiByteToWideChar(CP_ACP, 0, pAnsi, -1, pUnicodeBuffer, nBufferSize);
	if ((result > 0) && (pUnicodeBuffer != NULL))
		pUnicodeBuffer[result-1] = 0;

	return result;
}

简单实用

CString strBuf;
int nSize = Unicode2UTF8(strBuf, NULL, 0);
char* szBuf = new char[nSize];
Unicode2UTF8(strBuf, szBuf, nSize);

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

相关文章

  • 详解C语言中的#define宏定义命令用法

    详解C语言中的#define宏定义命令用法

    有的时候为了程序的通用性,可以使用#define预处理宏定义命令,它的具体作用就是方便程序段的定义和修改,下面就来详解C语言中的#define宏定义命令用法.
    2016-05-05
  • C++如何获取系统信息 C++获取IP地址、硬件信息等

    C++如何获取系统信息 C++获取IP地址、硬件信息等

    这篇文章主要为大家详细介绍了C++如何获取系统信,C++获取IP地址、硬件信息等,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-04-04
  • C语言之关于二维数组在函数中的调用问题

    C语言之关于二维数组在函数中的调用问题

    这篇文章主要介绍了C语言之关于二维数组在函数中的调用问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-07-07
  • MFC实现字幕滚动效果

    MFC实现字幕滚动效果

    这篇文章主要为大家详细介绍了MFC实现滚动字幕,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-05-05
  • 简述C语言中system()函数与vfork()函数的使用方法

    简述C语言中system()函数与vfork()函数的使用方法

    这篇文章主要介绍了简述C语言中system()函数与vfork()函数的使用方法,是C语言入门学习中的基础知识,需要的朋友可以参考下
    2015-08-08
  • Qt自定义控件实现多彩色仪表盘

    Qt自定义控件实现多彩色仪表盘

    这篇文章主要为大家详细介绍了Qt自定义控件实现多彩色仪表盘,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-12-12
  • C语言写一个散列表

    C语言写一个散列表

    这篇文章主要介绍了C语言写一个散列表,散列表,就是下标可以为字母的数组。更多内容和小编一起学习下面内容吧
    2022-01-01
  • C语言中如何利用循环嵌套输出一个菱形

    C语言中如何利用循环嵌套输出一个菱形

    这篇文章主要介绍了C语言中如何利用循环嵌套输出一个菱形问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-02-02
  • window调用api列出当前所有进程示例

    window调用api列出当前所有进程示例

    这篇文章主要介绍了window调用api列出当前所有进程示例,需要的朋友可以参考下
    2014-04-04
  • C语言枚举与联合图文梳理讲解

    C语言枚举与联合图文梳理讲解

    枚举顾名思义就是把所有的可能性列举出来,像一个星期分为七天我们就可以使用枚举,联合体是由关键字union和标签定义的,和枚举是一样的定义方式,不一样的是,一个联合体只有一块内存空间,什么意思呢,就相当于只开辟最大的变量的内存,其他的变量都在那个变量占据空间
    2023-01-01

最新评论