自己写的一个函数。 如果字符串中含有中文,简单截取会出现乱码,简单的做法是,把它先转换成宽字符然后截取,完成后再转回来。当然,对于本身是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 
|