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中是完全正常的.
如图:
eVC++就是eVC++啊
于是改用如下代码:
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);
}
乱码没有了:
eVC++就是eVC++啊

问了一下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字符串的转换。

你可能感兴趣的:(vc++)