有許多人在做項目的時候都會遇到字符編碼的不一致導致的亂碼問題,那如何去解決呢?在Linux系統上可以通過iconv函數族來進行編碼轉換,但有時候我們并不需要全部的字符集,因為可能會占用比較大的空間,本文主要支持CP437編碼格式
庫文件下載:https://ftp.gnu.org/pub/gnu/libiconv/
1.下載完成后直接解壓
tar -xvf libiconv-1.15.tar.gz
2.進入目錄,編寫編譯腳本,build.sh
CC=gcc
HOST=
TARGET=
DIR=/root/linux/direcho $DIR./configure CC=$CC --target=$TARGET --host=$HOST --prefix=$DIR --enable-extra-encodingsmake && make install
上面注意 --enable-extra-encodings是打開擴展字符集
需要根據自己使用場合修改交叉編譯鏈
3.執行腳本進行編譯
chmod +x build.sh
./build.sh
4.編譯完成后
5.這里執行strip壓縮體積
6.我們執行程序看看都包含哪些字符集,可以看到支持了所有的字符,有好多是我們不需要的,下面進行裁剪
該iconv可執行文件依賴上面的庫,如果導入arm設備要導入相應的庫文件
7.進入lib目錄編輯iconv.c文件,屏蔽一些無用代碼
//#define USE_AIX
//#define USE_OSF1
#define USE_DOS
//#define USE_EXTRA
首先屏蔽一些宏,然后編譯發現還是有一些我們不想要的字符集
8.編輯lib/encodings_dos.def文件刪除不需要的字符集,同時刪除aliases_dos.h文件的相關定義,最后刪除canonical_dos.h中的一些報錯就可以了
9.經過strip后這個時候在看就小的多了
再次使用iconv查看支持的字符集就可以了
網上給出的另一種裁剪方法:
libiconv庫裁剪