自己写的一个函数。
如果字符串中含有中文,简单截取会出现乱码,简单的做法是,把它先转换成宽字符然后截取,完成后再转回来。当然,对于本身是Unicode的程序,直接截取就行了,不必转换。
///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
BOOL TruncStringLeft(LPTSTR lpszSource, int nCnt)
{
ATLASSERT(lpszSource);
if(NULL == lpszSource || nCnt <1 || !lpszSource[0])
return FALSE;
WCHAR wszWide[MAX_PATH * 2];
#ifdef UNICODE
_tcscpy(wszWide, lpszSource);
#else
MultiByteToWideChar(CP_ACP, 0, lpszSource, -1, wszWide, ARRAYSIZE(wszWide));
#endif
if(wcslen(wszWide)>nCnt)
wszWide[nCnt] = 0;
#ifdef UNICODE
_tcscpy(lpszSource, wszWide);
#else
WideCharToMultiByte(CP_ACP, 0, wszWide, -1, lpszSource, MAX_PATH, NULL, NULL);
#endif
return TRUE;
}
///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
一些相关的讨论:
http://dev.csdn.net/develop/article/66/66387.shtm
http://community.csdn.net/Expert/topic/3906/3906053.xml?temp=.4827692