在Windows C程序中使用Unicode编码
生活随笔
收集整理的這篇文章主要介紹了
在Windows C程序中使用Unicode编码
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
一、Unicode字符/字符串使用L前綴
在windows的C/C++項目中,如果要使用Unicode編碼,則必須在字符串或字符前加上’L’前綴,Unicode字符串以兩個0結尾\0\0。如果不加L前綴,則表示使用默認的擴展ASCII編碼(在中國大陸應該就是GB2312)
#include <locale.h>int main() {setlocale(LC_ALL, ""); // 設置地域,第二個參數字符串為空表示使用當前操作系統的地域char s1[] = "中A國"; // 使用多字節字符集(gb2312)wchar_t s2[] = L"中A國"; // 使用unicode字符集printf("%s\n", s1); wprintf(L"%s\n", s2); // 必須setlocale告訴控制臺使用Unicode編碼顯示return 0; }二、Unicode版本的字符串函數
寬字符有一套專門的函數。
#include <locale.h> #include <string.h> int main() {setlocale(LC_ALL, ""); // 設置地域,第二個參數字符串為空表示使用當前操作系統的地域char s1[] = "中A國"; // 使用多字節字符集(gb2312)wchar_t s2[] = L"中A國"; // 使用unicode字符集printf("%s\n", s1); wprintf(L"%s\n", s2); // 必須setlocale告訴控制臺使用Unicode編碼顯示printf("%d\n", strlen(s1));printf("%d\n", wcslen(s2));return 0; }擴展ASCII中,英文占1字節,高位是0,中文占2字節,高位是1。因此第一個字符串的長度是2+1+2=5;第二個字符串使用Unicode,固定每個字符不管英文中文都是2字節, 寬字符版本的函數計算出來的長度是字符的個數,也就是3。
三、使用宏解決兼容性問題
當項目由多人開發,可能出現一個問題:一個人用的項目是多字節字符集編碼,另一個人用的是Unicode編碼,這樣兩人的代碼合并就會出現問題。所以windows提供了一系列宏,在程序中使用宏,會自動根據項目的字符集來替換成相應類型。
總結
以上是生活随笔為你收集整理的在Windows C程序中使用Unicode编码的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 导入表注入原理和C语言实现
- 下一篇: 我的第一个windows应用程序