UCS2编码与解码

/*--------------------------------------------------------------*/

//UCS2编码

// 输入: pSrc - 源字符串指针

//nSrcLength - 源字符串长度

// 输出: pDst - 目标编码串指针

// 返回: 目标编码串长度

/*----------------------------------------------------------------*/

intgsmEncodeUcs2(const char* pSrc, unsigned char* pDst, int nSrcLength)

{

intnDstLength; // UNICODE宽字符数目

WCHARwchar[128]; // UNICODE串缓冲区

 

// 字符串-->UNICODE串

nDstLength= MultiByteToWideChar(CP_ACP, 0, pSrc, nSrcLength, wchar, 128);

 

// 高低字节对调,输出

for(inti=0; i<nDstLength; i++)

{

*pDst++= wchar[i] >> 8; // 先输出高位字节

*pDst++= wchar[i] & 0xff; // 后输出低位字节

}

 

// 返回目标编码串长度

returnnDstLength * 2;

}

/*----------------------------------------------------*/

//UCS2解码

// 输入: pSrc - 源编码串指针

//nSrcLength - 源编码串长度

// 输出: pDst - 目标字符串指针

// 返回: 目标字符串长度

/*-------------------------------------------------------*/

intgsmDecodeUcs2(const unsigned char* pSrc, char* pDst, int nSrcLength)

{

intnDstLength; // UNICODE宽字符数目

WCHARwchar[128]; // UNICODE串缓冲区

 

// 高低字节对调,拼成UNICODE

for(inti=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';

 

// 返回目标字符串长度

returnnDstLength;

}转自bbs.sendsms.cn

posted @ 2015-11-23 17:00  小小笛子  阅读(1569)  评论(0编辑  收藏  举报