字符编码的使用 字符编码主要分两种:MBCS以及 Unicode。 以 C/CC++ 为例,以 char 为单位的数组使用MBCS编码(如 ASCII,GB2312,BIG5),以wchar_t 为单位的数组使用Unicode作为编码。 比如你的程序中使用: char szTitle[] = "窗体标题“; 此时,szTitle字符串使用的的是MBCS编码,如果用户的操作系统不是中文的Windows,你的程序将无法正常显示! 所以,要换成Unicode方式: wchar_t szTitle[] = L"窗体标题"; 此时,szTitle字符串使用的的是Unicode编码,加入你的程序以unicode方式编译,在任何语言的Windows上都能显示正常。 字符编码的转换 有时候你从外部文件读进来的字符串是MBCS编码(如GB2312),而你程序里面都是统一用Unicode处理字符串,这时候要进行字符编码转换。 Windows为我们提供了很好用的API函数 MultiByteToWideChar 和 WideCharToMultiByte 帮我们轻松实现转换。 代码如下: GB2312 转换成 Unicode: CODE: wchar_t* GB2312ToUnicode(const char* szGBString) BIG5 转换成 Unicode:{ UINT nCodePage = 936; //GB2312 int nLength=MultiByteToWideChar(nCodePage,0,szGBString,-1,NULL,0); wchar_t* pBuffer = new wchar_t[nLength+1]; MultiByteToWideChar(nCodePage,0,szGBString,-1,pBuffer,nLength); pBuffer[nLength]=0; return pBuffer; } CODE: wchar_t* BIG5ToUnicode(const char* szBIG5String) Unicode 转换成 GB2312:{ UINT nCodePage = 950; //BIG5 int nLength=MultiByteToWideChar(nCodePage,0,szBIG5String,-1,NULL,0); wchar_t* pBuffer = new wchar_t[nLength+1]; MultiByteToWideChar(nCodePage,0,szBIG5String,-1,pBuffer,nLength); pBuffer[nLength]=0; return pBuffer; } CODE: char* UnicodeToGB2312(const wchar_t* szUnicodeString) Unicode 转换成 BIG5:{ UINT nCodePage = 936; //GB2312 int nLength=WideCharToMultiByte(nCodePage,0,szUnicodeString,-1,NULL,0,NULL,NULL); char* pBuffer=new char[nLength+1]; WideCharToMultiByte(nCodePage,0,szUnicodeString,-1,pBuffer,nLength,NULL,NULL); pBuffer[nLength]=0; return pBuffer; } CODE: char* UnicodeToBIG5(const wchar_t* szUnicodeString) 繁体和简体的相互转换{ UINT nCodePage = 950; //BIG5 int nLength=WideCharToMultiByte(nCodePage,0,szUnicodeString,-1,NULL,0,NULL,NULL); char* pBuffer=new char[nLength+1]; WideCharToMultiByte(nCodePage,0,szUnicodeString,-1,pBuffer,nLength,NULL,NULL); pBuffer[nLength]=0; return pBuffer; } 利用Unicode作为媒介,还可以做出很有意思的应用。在处理中文过程中,一个经常用到的功能就是繁体和简体的互相转换。 代码如下: 繁体中文BIG5 转换成 简体中文 GB2312 CODE: char* BIG5ToGB2312(const char* szBIG5String) 简体中文 GB2312 转换成 繁体中文BIG5{ LCID lcid = MAKELCID(MAKELANGID(LANG_CHINESE,SUBLANG_CHINESE_SIMPLIFIED),SORT_CHINESE_PRC); wchar_t* szUnicodeBuff = BIG5ToUnicode(szBIG5String); char* szGB2312Buff = UnicodeToGB2312(szUnicodeBuff); int nLength = LCMapString(lcid,LCMAP_SIMPLIFIED_CHINESE, szGB2312Buff,-1,NULL,0); char* pBuffer = new char[nLength + 1]; LCMapString(0x0804,LCMAP_SIMPLIFIED_CHINESE,szGB2312Buff,-1,pBuffer,nLength); pBuffer[nLength] = 0; delete[] szUnicodeBuff; delete[] szGB2312Buff; return pBuffer; } CODE: char* GB2312ToBIG5(const char* szGBString) { LCID lcid = MAKELCID(MAKELANGID(LANG_CHINESE,SUBLANG_CHINESE_SIMPLIFIED),SORT_CHINESE_PRC); int nLength = LCMapString(lcid,LCMAP_TRADITIONAL_CHINESE,szGBString,-1,NULL,0); char* pBuffer=new char[nLength+1]; LCMapString(lcid,LCMAP_TRADITIONAL_CHINESE,szGBString,-1,pBuffer,nLength); pBuffer[nLength]=0; wchar_t* pUnicodeBuff = GB2312ToUnicode(pBuffer); char* pBIG5Buff = UnicodeToBIG5(pUnicodeBuff); delete[] pBuffer; delete[] pUnicodeBuff; return pBIG5Buff; } 文本文件读写的编码问题 |
字符编码的使用和转换(转)
晴 温度:23℃-32℃
前段時間給我的拼音輸入法添加了筆畫輸入、半角切換、中英文標點符號切換的功能,今天又完成了輸出繁體字的功能。通過完成輸出繁體字功能,現在對windows下漢字編碼有了一些了解。 一個完整的拼音輸入法差不多完成了。 后面還要制作幫助文件,安裝程序,還有就是想再找個好一點的詞組庫。 |
输入法编程-随应用程序的窗口移动
看了自由拼音输入法的源代码,发现输入法的窗口不能随着应用程序的窗口移动而移动。 经过到网上找资料,并进行调试,找到了原因。 只要在处理下面这个消息时, case IMN_SETCOMPOSITIONWINDOW: 进行窗口移动,就可以了。 自由拼音输入法的代码如下: case IMN_SETCOMPOSITIONWINDOW: ptSrc = lpIMC->cfCompForm.ptCurrentPos; lpUIExtra->uiComp.pt.x = ptSrc.x + szOffset.cx; break; |
C语言字符串函数大全(转)
函数名: stpcpy #include int main(void) stpcpy(string, str1); 函数名: strcat #include int main(void) strcpy(destination, Borland); printf("%s\n", destination); 函数名: strchr #include int main(void) strcpy(string, "This is a string"); 函数名: strcmp #include int main(void) ptr = strcmp(buf2, buf1); ptr = strcmp(buf2, buf3); return 0; 函数名: strncmpi #include int main(void) ptr = strcmpi(buf2, buf1); if (ptr > 0) if (ptr <> if (ptr == 0) return 0; 函数名: strcpy #include int main(void) strcpy(string, str1); 函数名: strcspn #include int main(void) length = strcspn(string1, string2); return 0; 函数名: strdup #include int main(void) dup_str = strdup(string); return 0; 函数名: stricmp #include int main(void) ptr = stricmp(buf2, buf1); if (ptr > 0) if (ptr <> if (ptr == 0) return 0; 函数名: strerror #include int main(void) 函数名: strcmpi #include int main(void) ptr = strcmpi(buf2, buf1); if (ptr > 0) if (ptr <> if (ptr == 0) return 0; 函数名: strncmp #include int main(void) { ptr = strncmp(buf2,buf1,3); ptr = strncmp(buf2,buf3,3); return(0); 函数名: strncmpi #include int main(void) ptr = strncmpi(buf2,buf1,3); if (ptr > 0) if (ptr <> if (ptr == 0) return 0; 函数名: strncpy #include int main(void) strncpy(string, str1, 3); 函数名: strnicmp #include int main(void) ptr = strnicmp(buf2, buf1, 3); if (ptr > 0) if (ptr <> if (ptr == 0) return 0; 函数名: strnset #include int main(void) printf("string before strnset: %s\n", string); return 0; 函数名: strpbrk #include int main(void) ptr = strpbrk(string1, string2); if (ptr) return 0; 函数名: strrchr #include int main(void) strcpy(string, "This is a string"); 函数名: strrev #include int main(void) printf("Before strrev(): %s\n", forward); 函数名: strset #include int main(void) printf("Before strset(): %s\n", string); 函数名: strspn #include int main(void) length = strspn(string1, string2); 函数名: strstr #include int main(void) ptr = strstr(str1, str2); 函数名: strtod #include int main(void) printf("Enter a floating point number:"); 函数名: strtok #include int main(void) /* strtok places a NULL terminator /* A second call to strtok using a NULL 函数名: strtol #include int main(void) /* strtol converts string to long integer */ return 0; 函数名: strupr #include int main(void) /* converts string to upper case characters */ 函数名: swab #include char source[15] = "rFna koBlrna d"; int main(void) |
晴 温度:22℃-30℃
昨天我的侄子开始上小学了,呵呵,跟我念的是同一所小学校,景德镇市第一小学。 时间过的真快,一恍就二十多年,没想到今天我的侄子走同样的路去上同样的小学。想起我在小学校操场上跟同学玩耍,嘻闹,升国旗,在课堂上开小猜,做小动作,跟同学在上课的时候讲话,放学的时候被老师留校,罚写课文,就象昨天的事一样。 |
温度:20℃-24℃ 中雨转小雨
今天下了雨,气温转冷了,下午工作完回家的时候,身上穿了件短袖白衬衫,路上感觉有点冷。我喜欢这样的天气,因为我这人比较贪凉,而且因为下了雨,所以空气干净,这让我觉得很舒服。 |