Dword、LPSTR、LPWSTR、LPCSTR、LPCWSTR、LPTSTR、LPCTSTR

因为本来转化后的字符串变得可以修改了,造成了安全隐患。

正确的转化方法为:

1 CString str("string");
LPTSTR  pStr = str.GetBuffer();
2
3 wcscpy(pWchar,str);

方法二:使用wcscpy_s()函数

这个函数是上一个函数的安全版本,调用上一个函数如果pWchar的内存不足时,容易引发意味的错误,但是wcscpy_s()则不会,应该其内存大小已经指定出来了:

1 CString str("string");
WCHAR  pWchar[100];
2
3 _tcscpy(pStr,str);

方法四:使用_tcscpy_s()函数

同wcscpy_s()一样,_tcscpy_s()函数也是_tcscpy()函数的安全版本:

1 CString str("string");
WCHAR  pStr[100];
2
3 <code bold"="">wcstombs(pChar,str,100);

方法二:使用wcstombs_s()函数

同上面一样,wcstombs_s()是wcstombs()的安全版本:

总结:

      上面一会使用strcpy(),一会使用wcscpy(),一会又使用_tcscpy(),这三者有什么关系呢,其实strcpy()处理的就是 ASCII编码的字符,像char,而wcscpy()处理的是Unicode 编码,_tcscpy()则是一个宏,如果你使用的是ASCII编码,那么_tcscpy()表示的就是strcpy(),如果你使用的是Unicode 编码,那么_tcscpy()表示的就是wcscpy(),这可以通过定义_UNICODE或UNICODE宏来实现。你可能已经知道了为什么要定义这么 一个宏,对!就是为了代码的移植。还有一个函数就是wcstombs(),这个函数是干什么用的呢?其实除了Unicode编码,还有一个编码,那就是多 字节编码,通常用的是双字节编码,vc就支持这种编码,函数wcstombs()就是为了实现多字节和单字节转换而设计的。


 

 

你可能感兴趣的:(C++,内存)