LPCWSTR 和char数组的转换

来源:百度知道 编辑:UC知道 时间:2024/06/06 05:47:27
char buffer[80];
sprintf(buffer, "LOWORD(wparam) = %d, HIWORD(wparam) = %d ",
LOWORD(wparam), HIWORD(wparam));

// print text at a random location
TextOut(hdc,220,100,buffer,strlen(buffer));
错误 : “TextOutW”: 不能将参数 4 从“char [80]”转换为“LPCWSTR”
期待解决!

LPCWSTR中的W是宽字符的意思,是UNICODE,就是说不是传统的char这种单字节字符,而是一个字符占两字节.

编译器把TextOut解释成了TextOutW,说明你的代码中某个地方定义了UNICODE开关,编译环境成了宽字节的,要把这个定义去掉.

MSDN上的DataType上是这么说的,LPTSTR是什么呢?
#ifdef UNICODE
typedef LPWSTR LPTSTR;
#else
typedef LPSTR LPTSTR;
#endif
而LPWSTR是针对wchar_t的,LPSTR是针对char的,
typedef CHAR *LPSTR;
typedef char CHAR;
可见如果没有定义UNICODE的话, char *就是LPTSTR,而const char *就是LPCTSTR,那个T表示的是TCHAR(char[ascii],wchar_t[UNICODE])。
================
我的意思是如果你没有在命令喊使用“/D UNICODE”或者源码一开始“#define UNICODE”的话LPTSTR跟char *是一样的。你这里出现了乱码的话应该先看看你的char tmpDir[]有没有出现乱码。你看这个程序:
#include <Windows.h>
#include <tchar.h>
int _tmain()
{
char a [] = "abcdefg";
LPCTSTR l1 = (LPCTSTR)a;
char b [] = "你好啊。";
LPCTSTR l2 = (LPCTSTR)b;
_tprintf(_T("%s\n%s\n"), l1, l2);
return 0;
}