Qt 選擇性編譯和庫裁減是本文將要介紹的內容,編譯一次Qt要耗費太多的時間,常常是越著急用它,編起來越慢。其實通過很簡單的幾招可以幫你節省編譯的時間。下面就一一道來:
編譯之前確定哪些功能是不必要的,對編譯樹進行簡單裁剪
比如最常見的,像demos, examples,雖然很有參考價值,但完全可以放在后面用到的時候再單獨編譯小工程,這樣可以節省不少時間。經過實踐,最簡單的方法是修改configure文件,在該文件中有個指定編譯目錄的字段:
- QT_DEFAULT_BUILD_PARTS=”libs tools examples demos docs translations”
可以把examples、demos和docs從這里去掉,但要注意,別的可不能隨便去掉。
如果在后面的使用中發現有些小工程需要編譯了,可以采用一般編譯Qt程序的方法,即用Qt安裝目錄bin下的qmake來生成Makefile,同樣可以編譯和測試例子代碼,一點也不影響使用。
裁剪Qt模塊
Qt從4版本開始采用了模塊化的形式,將獨立的功能封裝在獨立的庫里,所以可以很簡單的去掉一些不需要的庫,這樣也能節省編譯時間和對硬盤空間的占用。 Qt的configure配置提供了一些設置模塊的方法,如它支持-no-svg和-no-webkit,通過configure的時候加這些選項就可以去掉這部分支持。相應的還有很多小的功能可以通過configure參數的形式配置,具體的參考configure –help的輸出。在查看configure幫助的時候特別要注意加*號的內容,也就是Qt默認的configure選項,有的時候默認選項可不一定是討人喜歡的哦。
Qt桌面版本默認會盡量多的編譯feature進去,這樣有一定的好處,就是用戶可以用到所有的Qt功能,但壞處也很明顯,那就是編譯出來的Qt超級大,特別是編譯debug版本,基本上要占1到2G的空間,所以個人感覺研究一下configure的選項還是很有必要的。另外, 默認狀況下有些插件是不會編譯的,比如數據庫插件,往往需要用戶自己根據需要編譯,這一點也要注意。
針對嵌入式版本的配置
Qt的嵌入式版本本身就支持feature裁剪,我們可以充分利用這一特性讓Qt庫盡量變小。具體的做法是要做一個自己的qconfig-[myconfig].h特性文件,該文件中定義你要去掉Qt中的哪些feature。在configure的時候加“-qconfig myconfig” 選項, Qt就會根據你給出的配置文件來編譯,以達到裁剪的目的。這里要強調一下,這種裁剪方式只適用于嵌入式版本。這里的myconfig可以用任何你喜歡的名字來代替。
在qt的代碼中已經給出了一些qconfig頭文件的例子,默認編譯采用full config也就是
不裁剪任何feature。所有Qt預定義好的qconfig文件,可以在src/corelib/global/下找到,包括qconfig-minimal.h, qconfig-small.h, qconfig.medium.h,qconfig-large.h和qconfig-dist.h,也就是從裁剪量由多到少都有據可依。如果要添加你自己的配置文件,要在src/corelib/global下建立一個形如qconfig-xxx.h的文件,這個xxx也就是你要在configure的時候傳入的qconfig參數。筆者測試使用的Qt版本是4.4.1,這個版本的build system有個小毛病,就是如果你指定的qconfig參數實際上沒有qconfig-xxx.h文件對應, build不會停止,它只會給出一個不起眼的提示,編譯過程會繼續, 這一點挺讓人費解的。而且這種情況下Qt編譯使用的配置基本上和fullconfig相同,鑒于它的讓人迷惑的舉動,個人覺得有必要提醒大家一下,使用自定義qconfig的時候一定要確定配置文件放對了位置,而且qconfig參數給的正確。
一般我們的建議是在桌面上測試階段編譯一個full的版本,再根據你的項目使用Qt feature的情況總結哪些可去掉的feature。 feature之間有千絲萬縷的依賴關系,這個問題也是困擾很多人的難點所在。具體的依賴可以查閱src/corelib/global/qfeatures.h和src/corelib/global/qfeatures.txt(描述依賴關系的文檔)。另外,Qt里還提供了一個可視化的配置依賴的工具,叫做qconfig,在QTDIR/tools/qconfig目錄。該工具需要基于Qt桌面版本編譯。如在我的linux系統下可以用下面的命令來編譯:
- $ cd qt-embedded-linux-commercial-4.4.1/tools/qconfig
- $ /usr/local/Trolltech/Qt-4.4.3/bin/qmake
- $ make
編譯成功后運行./qconfig,初始要打開qfeatures.txt. Qconfig讀取該文件生成一個樹狀圖,該圖很清楚的顯示出feature之間的依賴關系。如下圖所示,如果你去掉了LINEEDIT這個feature,用到該控件的combobox也就不能繼續使用了。有了這個工具裁剪Qt變得簡潔直觀,方便了很多。
選定了你要去掉的feature后點擊菜單File->Save As..會彈出保存文件的頁面,文件名字應該定義成qconfig-xxx.h的形式,這樣你在configure的時候就可以傳入相應的qconfig參數了。你還可以通過選擇File->Open打開現有的qconfig-xxx.h文件,通過修改已經有的文件更快的編輯配置。
根據筆者測試,未經裁剪的qte4.4.1編譯出來為:
- libQtCore.so是2.6M
- libQtGui.so是9.5M
如果用small來編譯,就能縮小為:
- libQtCore.so是2.0M
- libQtGui.so是5.7M
差異還是比較明顯的。
小結:Qt 選擇性編譯和庫裁減的內容介紹完了,希望本文對你有所幫助。更多內容請參考編輯推薦。
【編輯推薦】