自各儿写函数实现方便的Unicode/ANSI编码转换

自己写函数实现方便的Unicode/ANSI编码转换
最近写毕业设计,为了程序通用性使用的Unicode编码,但在Socket编程这方面要经常Unicode和ANSI编码相互转换,很麻烦,今天实在烦的不行了,就干脆写两个方便点的自定义函数方便调用。

代码实在是相当简单,没有一点技术含量,不过的确省了我很多心,真应该一开始就写这个。

/*
By zerosoul @ 2011.2.26
这两个函数的优点是调用方便返回值直接就是转换后的字符串
在VC的程序中,可以把这段代码写入stdafx.cpp,然后再stdafx.h填下面两行,就是全局函数了,在哪都可以调用:
extern TCHAR* Ansi2Unicode(char* szMultiByte);
extern char* Unicode2Ansi(TCHAR* szWideChar);
*/
#include "stdafx.h"
#include "stdio.h"  
#include "windows.h"  

//ANSI_2_UNICODE
TCHAR* Ansi2Unicode(char* szMultiByte)
{
	int nLen = MultiByteToWideChar(CP_ACP,NULL,szMultiByte,-1,NULL,0);  
	if (0 == nLen)
	{
		_tprintf(_T("MultiByteToWideChar() failed, Error Code : [%d]\n"),GetLastError());
		return NULL;
	}
	TCHAR* szWideChar = new TCHAR[nLen];  //Unicode宽字节编码字符串szWideChar  
	MultiByteToWideChar(CP_ACP,NULL,szMultiByte,-1,szWideChar,nLen); //开始转换  
	return szWideChar;
}

//UNICODE_2_ANSI
char* Unicode2Ansi(TCHAR* szWideChar)
{
	int nLen = WideCharToMultiByte(CP_ACP,NULL,szWideChar,-1,NULL,0,NULL,NULL);  
	if (0 == nLen)
	{
		_tprintf(_T("WideCharToMultiByte() failed, Error Code : [%d]\n"),GetLastError());
		return NULL;
	}
	char* szMultiByte = new char[nLen];  //Unicode宽字节编码字符串szWideChar  
	WideCharToMultiByte(CP_ACP,NULL,szWideChar,-1,szMultiByte,nLen,NULL,NULL); //开始转换  
	return szMultiByte;
}

int _tmain(int argc, _TCHAR* argv[])
{
	char strMultiByte[] = "zerosoulANSI\n";   //ANSI多字节编码字符串strMultiByte  
	TCHAR strWideChar[] = L"zerosoulUNICODE\n"; //Unicode宽字节编码字符串strWideChar  
	_tprintf(Ansi2Unicode(strMultiByte));
	printf(Unicode2Ansi(strWideChar));  
	return 0;
}