?? uncodegb.cpp
字號:
// UncodeGB.cpp : 定義控制臺應用程序的入口點。
//
#include "stdafx.h"
#include "unicodeGBTrans.h"
#include <Windows.h>
#include <iostream>
using namespace std;
int gsmEncodeUcs22(const char* pSrc, unsigned char* pDst, int nSrcLength);
int gsmDecodeUcs22(const unsigned char* pSrc, char* pDst, int nSrcLength);
int _tmain(int argc, _TCHAR* argv[])
{
char gb[]="我們是124df";
char toGB1[256];
char toGB2[256];
//WCHAR unChar[]={_T"124df我們是"};
unsigned char ucsChar1[256];
unsigned char ucsChar2[256];
cout<<"GB2312:"<<gb<<endl;
int ucsLen=gsmEncodeUcs22(gb,ucsChar1,strlen(gb));
cout<<ucsChar1<<endl;
int ucslen2=gsmEncodeUcs2(gb,ucsChar2,strlen(gb));
cout<<ucsChar2<<endl;
gsmDecodeUcs22(ucsChar1,toGB1,ucsLen);
gsmDecodeUcs2(ucsChar2,toGB2,ucslen2);
cout<<toGB1<<endl;
cout<<toGB2<<endl;
return 0;
}
int gsmDecodeUcs22(const unsigned char* pSrc, char* pDst, int nSrcLength)
{
int nDstLength; // UNICODE寬字符數目
WCHAR wchar[128]; // 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;
}
int gsmEncodeUcs22(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; // 后輸出低位字節
}
// TRACE("%s",wchar);
// 返回目標編碼串長度
return nDstLength * 2;
}
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -