Blaze

Back Again

 

eVC++就是eVC++啊

在VC++6.0正常的一段代码:

void CMessageboxView::OnLButtonDown(UINT nFlags, CPoint point) 
{
    MessageBox(
"LButtonDown");
    
// TODO: Add your message handler code here and/or call default
    CView::OnLButtonDown(nFlags, point);
}

在eVC++4.0中编译错误:
error C2664: 'MessageBoxW' : cannot convert parameter 1 from 'char [4]' to 'const unsigned short *'
        Types pointed to are unrelated; conversion requires reinterpret_cast, C-style cast or function-style cast
Error executing cl.exe.

 于是进行显式类型转换,改为MessageBox((LPCTSTR)"LButtonDown");
成功地弹出了消息框,但是里面地文字是乱码.但是这段代码在VC++6.0中是完全正常的.
如图:

于是改用如下代码:
void CMessageboxView::OnLButtonDown(UINT nFlags, CPoint point) 
{
    CString myStr
="LButtonDown";
    MessageBox((LPCTSTR)myStr);
    
// TODO: Add your message handler code here and/or call default
    CView::OnLButtonDown(nFlags, point);
}
乱码没有了:


问了一下wangxz,他说应该用MessageBox(_T("LBUTTONDOWN")); ,即加入一个_T宏,用来把ANSI字符串转换为 UniCode.因为Wince只支持UNICODE,因此调用API时要使用宽字符串。(LPCTSTR)"LBUTTONDOWN"中字符串本身仍然是ANSI字符串,前面加强制转换并没有解决问题。_T是在TCHAR.H中定义的一个宏,它会根据你编译环境中UNICODE宏的设置来确定是将后面的字符串编译成ANSI的还是UNICODE的
在VC下,由于PC上的Windows系统同时支持ANSI和UNICODE,所以可以用,但如果你在编译环境中定义了UNICODE宏,也会出现问题。
而定义一个CString中间变量的办法之所以可以用是因为CString重载了(LPCTSTR)这个强制转换运算符,这样就由CString完成了从ANSI字符串向UNICODE字符串的转换。

posted on 2006-06-23 14:38  Blaze  阅读(1421)  评论(0编辑  收藏  举报

导航