关于Char* ,CString ,WCHAR*之间的转换问题

GDI+所有类的接口函数如果要传递字符串作为参数的话,似乎都用UNICODE串,即WCHAR*。我开始也被整得晕头转向,因为窗口编程所用往往是CString,用IO流读文件数据又得到char *。得益于网上牛人们的总结,我用到以下几种基本方法去实现三者间的转换:


代码段一:
char * 转WCHAR *:
::MultiByteToWideChar(CP_ACP,0,(const char *)res,int count,char * dest,int count);
类似地,WCHAR *转char *:
WideCharToMultiByte(CP_ACP,   0,.........);
CString 转WCHAR *:
wchar_t * p=str.AllocSysStrinig()
也有A2W(str)的,但是要包括ATL转换头文件#include;
并且在A2W前使用USES_CONVERSION宏。
其它:
char*转CString:
除了直接赋值外,还可使用CString::Format进行。
如char * p="sfdasf";
CString str=p; 或者str.Format("%s",p);
CString 转char *
1.直接强制类型转换:
 CString ss="sfasf";
  char *p=(LPSTR)(LPCSTR)ss;
2.CString::GetBuffer或LockBuffer
char * p=str.GetBuffer();
char * pt=str.LockBuffer();
WCHAR *转CString
在网上没有找到相关的文档,想想应该是可以直接赋值的
但是试验发现虽无编译错误,但是用中文的时候却生乱码,用字母的时候却是正常,想其中肯定没有错误,只是用MessageBox显示的时候乱码应该有其它原因,比如说使用了双字节字符集DBCS来显示汉字(纯属猜测而已)。总体来说在Windows编程中:#define UNICODE
则CString .TCHAR,等均用的是UNICODE码,一个字符占两个字节。


 


代码段二:


 


CString m_strCarNo = "吉A13546";//实际中在我的程序里"吉A13546"是从数据库中读的


WCHAR buffer[1024];
wcsset(buffer,0); 
MultiByteToWideChar(CP_ACP,0,(char*)LPCSTR(m_strCarNo),(int)strlen((char*)LPCSTR(m_strCarNo)),buffer,1024);
int nLength = wcslen(buffer);


SolidBrush brush(Color(255, 0, 0, 255));//颜色 字体
Gdiplus::Font font(L"Arial", 15, FontStyleRegular,UnitPixel);  
graphics.DrawString(buffer,nLength,&font,PointF(X-36,Y+16),&brush);


//注:font的定义也应如此




代码段三:


CString 是 MFC 的东西,转换成WCHAR,要用 A2W,或 T2CW,要包含头文件#include <atlconv.h>


CString str("Test");WCHAR buf[1024];


// 或自己动态分配USES_CONVERSION;


// 必须有这句wcscpy(buf, A2W((LPCSTR)str));


// 转换,也可用 wcsncpy如果用SDK:


Font myFont(L"Arial", 16);


PointF origin(0.0f, 0.0f);


SolidBrush blackBrush(Color(255, 0, 0, 0));


// DrawString 有几种参数设法,例如graphics.DrawString(buf,wcslen(buf),&myFont,origin,&blackBrush);


 


 


代码段四:


 


把char*转换为wchar_t*
用stdlib.h中的mbstowcs_s函数,可以通过下面的例子了解其用法:
 
char *CStr = "string to convert";
size_t len = strlen(CStr) + 1;
size_t converted = 0;
wchar_t *WStr;
WStr=(wchar_t*)malloc(len*sizeof(wchar_t));
mbstowcs_s(&converted, WStr, len, CStr, _TRUNCATE);
 
其结果是WStr中储存了CStr的wchar_t版本。
 
把wchar_t*转换为char*
和上面的方法类似,用stdlib.h中的wcstombs_s函数,例子:
 
wchar_t *WStr = L"string to convert";
size_t len = wcslen(WStr) + 1;
size_t converted = 0;
char *CStr;
CStr=(char*)malloc(len*sizeof(char));
wcstombs_s(&converted, CStr, len, WStr, _TRUNCATE);
 
这时WStr中的内容将被转化为char版本储存在CStr中。
 
另外还可以通过流的方法来char*类型转换为wchar_t*类型,但这样的转换得到的结果将是const类型,而类似的方法不能将wchar_t*类型转换为char*类型。
 
把(const)char*转换为const wchar_t*
需要用到 sstream 头文件:
 
char *cstr="string to convert";
wstringstream wss;
wss<<cstr;
 
再调用wss.str().c_str(); 即可得到 const wchar_t* 类型的返回值。
 
虽然stringstream流不能将wchar_t*转换成char*,但可以用来进行数值类型和字符串之间的转换,例如:
 
double d=2734792.934f;
stringstream ss;
ss<<d;
 
调用ss.str()可得到string类型字符串 ”273479e+006”,又如:
 
string str("299792458");
stringstream ss;
long i=0;
ss<<str;
ss>>i;
 
此时i=299792458。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值