Cstring, TCHAR*, char*的转换

最近老用到Cstring, TCHAR*, char*的转换.

找到一篇写得蛮详细的. 引用过来, 方便自己以后查阅.

char是类型TCHAR也是!不过他可以通过是否定义了UNICODE宏来判断到底是char还是w_char;

TCHAR是一种字符串类型,它让你在以MBCS和UNNICODE来build程序时可以使用同样的代码,不需要使用繁琐的宏定义来包含你的代码,而char代表ASCII的字符

#ifdef UNICODE
   typedef wchar_t TCHAR;
   #else
   typedef char TCHAR;
   #endif

所以用MBCS来build时,TCHAR是char,使用UNICODE时,TCHAR是wchar_t.
至于String,CString他们都是一种封装了字串处理的操作!
你可以打开他们的源代码找寻究竟!
CString属于VC的类库
string是标准C++的类库
string.h是C的库函数。

研究它们的源代好些!

TCHAR,char是可以同整型互换的类型。
String,CString代表了一块内存区域。

TCHAR 赋值

#include <tchar.h>

TCHAR szWindowText[256]=_T("QQ2006");

char*、TCHAR*转换CString
CString str(****)

下面详细写一下其它转换

view plaincopy to clipboardprint?
/* *********************************************************************  
* 函数: TransCStringToTCHAR  
* 描述:将CString 转换为 TCHAR*  
* 日期: 
***********************************************************************/ 
TCHAR* CPublic::CString2TCHAR(CString &str)   
{   
int iLen = str.GetLength();   
TCHAR* szRs = new TCHAR[iLen];   
lstrcpy(szRs, str.GetBuffer(iLen));   
str.ReleaseBuffer();   
return szRs;   
}  
/* *********************************************************************
* 函数: TransCStringToTCHAR
* 描述:将CString 转换为 TCHAR*
* 日期:
***********************************************************************/
TCHAR* CPublic::CString2TCHAR(CString &str)
{
int iLen = str.GetLength();
TCHAR* szRs = new TCHAR[iLen];
lstrcpy(szRs, str.GetBuffer(iLen));
str.ReleaseBuffer();
return szRs;
}

view plaincopy to clipboardprint?
/***********************************************************************  
* 函数: THCAR2Char  
* 描述:将TCHAR* 转换为 char*  
* 日期: 
***********************************************************************  
*/   
char* CPublic::THCAR2char(TCHAR* tchStr)   
{   
int iLen = 2*wcslen(tchStr);//CString,TCHAR汉字算一个字符,因此不用普通计算长度   
char* chRtn = new char[iLen+1]   
wcstombs(chRtn,tchStr,iLen+1);//转换成功返回为非负值   
return chRtn;   
}  
/***********************************************************************
* 函数: THCAR2Char
* 描述:将TCHAR* 转换为 char*
* 日期:
***********************************************************************
*/
char* CPublic::THCAR2char(TCHAR* tchStr)
{
int iLen = 2*wcslen(tchStr);//CString,TCHAR汉字算一个字符,因此不用普通计算长度
char* chRtn = new char[iLen+1]
wcstombs(chRtn,tchStr,iLen+1);//转换成功返回为非负值
return chRtn;
}

view plaincopy to clipboardprint?
/*  
***********************************************************************  
* 函数: CString2char  
* 描述:将CString转换为 char*  
* 日期: 
***********************************************************************  
*/   
char* CPublic::CString2char(CString &str)   
{   
int len = str.GetLength();   
char* chRtn = (char*)malloc((len*2+1)*sizeof(char));//CString的长度中汉字算一个长度   
memset(chRtn, 0, 2*len+1);   
USES_CONVERSION;   
strcpy((LPSTR)chRtn,OLE2A(str.LockBuffer()));   
return chRtn;   
}  
/*
***********************************************************************
* 函数: CString2char
* 描述:将CString转换为 char*
* 日期:
***********************************************************************
*/
char* CPublic::CString2char(CString &str)
{
int len = str.GetLength();
char* chRtn = (char*)malloc((len*2+1)*sizeof(char));//CString的长度中汉字算一个长度
memset(chRtn, 0, 2*len+1);
USES_CONVERSION;
strcpy((LPSTR)chRtn,OLE2A(str.LockBuffer()));
return chRtn;
}

//参考
///////////////////////
//Pocket PC上的UNICODE和ANSI字符串
//By Vassili Philippov, September 26, 2001.
//杨方思歧 译
////////////////////////
view plaincopy to clipboardprint?
/*  
***********************************************************************  
* 函 数 名:GetAnsiString  
* 描 述:将CString(unicode)转换为char*(ANSI)  
* 参 数:CString &s 要转换的CString  
* 返 回 值:返回转换结果  
* 创建日期: 
* 最后修改: 
***********************************************************************  
*/   
char* GetAnsiString(const CString &s)   
{   
int nSize = 2*s.GetLength();   
char *pAnsiString = new char[nSize+1];   
wcstombs(pAnsiString, s, nSize+1);   
return pAnsiString;   
}

本文来自CSDN博客:  http://blog.csdn.net/lsldd/archive/2009/08/05/4412531.aspx

以下是自己调试中遇到的问题:

/////////////在TCHAR*中存储的中文字符转换为char*时遇到的问题,

TCHAR tszName[MAX_PATH]=TEXT("刘小猪");

我一直认为求长度, 直接用 nLen = _tcslen(tszName)*sizeof(TCHAR);就可以了

调试过程中发现, 转换过来的字符总是少一个汉字.不明白为什么.

如果利用

int nLen = WideCharToMultiByte(CP_ACP, 0, tszName, -1, NULL, 0, NULL, NULL);

求出实际转换成char时的字符长度.

再去分配实际需要的内存空间的话就没有问题了.

char* pszName = new char[nLen*sizeof(char)];

WideCharToMultiByte(CP_ACP, 0, tszName, -1, pszName, nLen, NULL, NULL);

MultiByteToWideChar的使用:

int nLen = MultiByteToWideChar(CP_ACP, 0, pMultiByteStr, -1, NULL, 0);

TCHAR* pWideChar = new TCHAR[nLen * sizeof(TCHAR)];

MultiByteToWideChar(CP_ACP, 0, pMultiByteStr, -1, pWideChar, nLen);

原文地址:https://www.cnblogs.com/sideny/p/3290821.html