应用程序应该转换为支持Unicode的形式,应该遵循的基本准则如下:
1,开始将文本字符串想象为字符的数组,而不是char或字节的数组。
2,用通用数据类型,如TCHAR / PTSTR,来表示文本字符和字符串。
3,用明确的数据类型,如BYTE和PBYTE来表示字节、字节指针和数据缓冲区。
4,用TEXT或_T宏来表示字面量字符和字符串,但为保持一致性和更好的可读性,不要两都混用。
5,执行全局替换,如用PTSTR替换PSTR
6,修改与字符串有关的计算,如函数经常希望我们传给它缓冲区大小的字符数,而不是字节数。这意味着我们应该传入_countof(szByffer),而不是sizeof(szBuffer)。而且,如果需要为一个字符串分配一个内存块,而且知道字符中的字符数,那么要记住内存是以字节来分配的。这意味着我们必须调用malloc(nChar * sizeof(TCHAR)),而不是调用malloc(nChar)。如果出错,编译器将不会提供任何警告或错误信息,所以最好定义一个宏来避免犯错:#define chmalloc(nchar) (TCHAR*)malloc(nchar * sizeof(TCHAR))
7,避免使用printf系列函数,尤其不要用%s和%S字段类型进行ANSI与UNICODE字符串之间的相互转换,正确的做法是使用MultiByteToWideChar和WideCharToMultiByte函数。