int CcmppSocket::UCS2ToByte(char *src, int len)
{
   int ret=len;
unsigned char uchTmp = 0;
unsigned char * pchTmp=(unsigned char *)new char[len+1];
memset(pchTmp,0,len+1);
memcpy(pchTmp,src,len);
//高低字节转换
for (int i=0; i<len/2; i++) {
uchTmp = pchTmp[i*2];// 低
pchTmp[i*2] = pchTmp[i*2 + 1];    // 低 = 高
pchTmp[i*2 + 1] = uchTmp;// 高 = 低
}
// 转换成MultiByte形式.
try
{
ret = WideCharToMultiByte(CP_ACP, WC_COMPOSITECHECK, (LPCWSTR)pchTmp, len/2, src, len, NULL, NULL);
        
}catch(...){}
src[ret]='\0';
delete []pchTmp;
return ret;
}
//当接收的全是中文时能转换,不会出现乱码,而当接收的有中文,英文,数字时就出现乱码,不能完全转换
请高手们赐教!!!!
CSDN里的stevecrisewu(月亮骑士) 告诉我:
用我的这个肯定没有问题int CSms::gsmDecodeUcs2(const unsigned char *pSrc, char *pDst, int nSrcLength)
{
int nDstLength;        // UNICODE宽字符数目
    WCHAR wchar[128];      // UNICODE串缓冲区
    
    // 高低字节对调,拼成UNICODE
    for(int i=0; i<nSrcLength/2; i++)
    {
        // 先高位字节
        wchar[i] = *pSrc++ << 8;
    
        // 后低位字节
        wchar[i] |= *pSrc++;
    }
    
    // UNICODE串-->字符串
    nDstLength = ::WideCharToMultiByte(CP_ACP, 0, wchar, nSrcLength/2, pDst, 160, NULL, NULL);
    
    // 输出字符串加个结束符    
    pDst[nDstLength] = '\0';    
    
    // 返回目标字符串长度
    return nDstLength;
}// UCS2编码
// pSrc: 源字符串指针
// pDst: 目标编码串指针
// nSrcLength: 源字符串长度
// 返回: 目标编码串长度
int CSms::gsmEncodeUcs2(const char *pSrc, unsigned char *pDst, int nSrcLength)
{
int nDstLength;        // UNICODE宽字符数目
    WCHAR wchar[128];      // UNICODE串缓冲区
    
    // 字符串-->UNICODE串
    nDstLength = ::MultiByteToWideChar(CP_ACP, 0, pSrc, nSrcLength, wchar, 128);
    
    // 高低字节对调,输出
    for(int i=0; i<nDstLength; i++)
    {
        // 先输出高位字节
        *pDst++ = wchar[i] >> 8;
        // 后输出低位字节
        *pDst++ = wchar[i] & 0xff;
    }
    
    // 返回目标编码串长度
    return nDstLength * 2;
}接收时候你要注意传递正确的数据长度,因为英文,数字转换到UCS2编码后会出现00,不能用strlen来判断字符串长度
我试了gsmDecodeUcs2(const unsigned char *pSrc, char *pDst, int nSrcLength)还是没用
是不是要先UCS2编码在UCS2解码
还是其它的方法