Qt編程涉及的術語和名詞(共3頁)_第1頁
Qt編程涉及的術語和名詞(共3頁)_第2頁
Qt編程涉及的術語和名詞(共3頁)_第3頁
全文預覽已結束

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領

文檔簡介

1、精選優(yōu)質(zhì)文檔-傾情為你奉上本節(jié)我們來介紹一下使用  編程過程中常用的術語和名字,它們不一定專屬于 Qt,在其它的 C/ 開發(fā)過程中也會使用到。ProjectProject 的中文翻譯是“項目”或者“工程”,這里的項目是指為實現(xiàn)某個相對獨立功能的程序代碼合集,這些代碼不單單是放在一塊,而是有相互之間的關聯(lián)性,并且有專門負責管理該項目的項目文件,比如:· Qt 使用 .pro 文件管理項目;· VC+ 則使用 .vcproj 作為項目文件。集成開發(fā)環(huán)境通常都是依據(jù)項目文件(.pro/.vcproj)管理和構建項目。Makefile即生成腳本,雖然可

2、以直接調(diào)用編譯器如 g+ 編譯程序,但是如果項目里的代碼文件變多了,哪些代碼文件更新了需要重新編譯,哪些代碼沒有改不需要重新編譯等等,靠程序員自己記憶去處理是比較麻煩的事,還有哪些代碼需要預處理或是鏈接哪些庫文件, 這些都是繁雜的過程。為了規(guī)范程序的編譯生成過程,產(chǎn)生了規(guī)范化的生成腳本,就是 Makefile,生成器 make 可以依據(jù)規(guī)范的 Makefile 自動生成目標程序或庫文件。 簡單的說,就是定義好 Makefile ,讓程序員只需要去關注如何編寫代碼,而生成程序過程中的臟活累活都交給 make 程序。 現(xiàn)在 Makefile 通常都有工具自動生成,如 qmake 工具, 這樣就大量

3、減輕了程序員的負擔。Debug 和 ReleaseDebug 即調(diào)試,Release 即發(fā)行。代碼編寫之后,生成的目標程序或庫文件通常不會絕對正確,或多或少有些毛?。╞ug), 因此需要進行糾錯調(diào)試(Debug)。調(diào)試過程中需要源代碼和二進制目標程序之間一一對應的關系, 這樣才能定位到錯誤代碼,所以 Debug 版本的程序是臃腫而不進行優(yōu)化的。 與之相對的是 Release 發(fā)行版,在糾正了發(fā)覺到的錯誤后,需要發(fā)布程序用于實際用途,實際應用時強調(diào)運行效率高,減少冗余代碼,因此會對二進制程序進行大量優(yōu)化,提升性能。這樣發(fā)布的二進制目標程序就是 Release 版。Debug 版本和 Releas

4、e 版本使用的庫文件不一樣:· Debug 版本程序通常鏈接的也是 Debug 版本的庫文件,比如 libQt5Guid.a/Qt5Guid.dll,庫文件的簡短名(不含擴展名)都是以 d 結尾的,Debug 庫通常都比較大 。· Release 版本程序鏈接的通常就是 Release 版本的庫文件,Release 版本庫文件名字比 Debug 版本庫文件少一個字母 d ,如 libQt5Gui.a/Qt5Gui.dll,而且 Release 版本庫一般都比 Debug 版本小很多,運行效率也高很多。C+11 標準時代在變化,C+ 標準也在前進。C+ 正式公布標準有 C+9

5、8、C+03、C+11。最新的 C+11 標準是2011年8月12日公布的,在公布之前該標準原名為 C+0x 。這是一次較大的修訂和擴充,建議讀者專門學一下。 Qt 從 4.8 版本就開始用 C+11 新特性了。編譯器里面開始支持 C+11 的版本是 MSVC 2010、 4.5、Clang 3.1,這之后版本的編譯器都在逐步完善對 C+11 的支持,現(xiàn)在新版本編譯器對新標準的支持都比較全面了。 Qt 官方在編譯 Qt5 庫的時候都是開啟 C+11 特性的,如果我們要在自己項目代碼啟用新標準,需要在 .pro 文件里面添加一行:CONFIG += c+11如果是 Qt4 版本則是添加

6、:gcc:CXXFLAGS += -std=c+0xMSVC 編譯器默認開啟 C+11 特性,GCC(g+命令)則需要自己添加選項 -std=c+0x ,上面 CXXFLAGS 就是為 GCC 編譯器(g+命令)添加 -std=c+0x 選項。Dynamic Link 和 Static LinkDynamic Link 即動態(tài)鏈接,Static Link 即靜態(tài)鏈接。動態(tài)鏈接庫目標程序通常都不是獨立個體,生成程序時都需要鏈接其他的庫,要用到其他庫的代碼。對于多個程序同時運行而言,內(nèi)存中就可能有同一個庫的多個副本,占用了太多內(nèi)存而干的活差不多。 為了優(yōu)化內(nèi)存運用效率,引入了動態(tài)鏈接庫(Dynam

7、ic Link Library),或叫共享庫(Shared Object)。使用動態(tài)鏈接庫時,內(nèi)存中只需要一份該庫文件,其他程序要使用該庫文件時,只要鏈接過來就行了。由于動態(tài)庫文件外置,鏈接到動態(tài)庫的目標程序相對比較小,因為剝離了大量庫代碼,而只需要一些鏈接指針。 使用動態(tài)庫,也意味著程序需要鏈接到如 *.dll 或 *.so 文件,得提前裝好動態(tài)庫文件,然后目標程序才能正常運行。靜態(tài)鏈接庫靜態(tài)庫就是將鏈接庫的代碼和自己編寫的代碼都編譯鏈接到一塊,鏈接到靜態(tài)庫的程序通常比較大,但好處是運行時依賴的庫文件很少,因為目標程序自己內(nèi)部集成了很多庫代碼。庫文件后綴Linux/Unix 系統(tǒng)里靜態(tài)庫擴展

8、名一般是 .a,動態(tài)庫擴展名一般是 .so 。Windows 系統(tǒng)里 VC 編譯器用的靜態(tài)庫擴展名一般是 .lib,動態(tài)庫擴展名一般是 .dll 。 MinGW 比較特殊,是將 GNU 工具集和鏈接庫從 Linux/Unix 系統(tǒng)移植到 Windows 里, 有意思的情況就出現(xiàn)了,MinGW 使用的靜態(tài)庫擴展名為 .a ,而其動態(tài)庫擴展名則為 .dll, .a 僅在生成目標程序過程中使用,.dll 則是在目標程序運行時使用。Explicit Linking 和 Implicit LinkingExplicit Linking 即顯式鏈接,Implicit Linking 即隱式鏈接,這兩種都是

9、動態(tài)鏈接庫的使用方式。 動態(tài)鏈接庫通常都有其導出函數(shù)列表, 告知其他可執(zhí)行程序可以使用它的哪些函數(shù)??蓤?zhí)行程序使用這些導出函數(shù)有兩種方式:一是在運行時使用主動加載動態(tài)庫的函數(shù),Linux 里比如用 dlopen 函數(shù)打開并加載動態(tài)庫,Windows 里一般用 LoadLibrary 打開并加載動態(tài)庫,只有當程序代碼執(zhí)行到這些函數(shù)時,其參數(shù)里的動態(tài)庫才會被加載,這就是顯式鏈接。顯式鏈接方式是在運行時加載動態(tài)庫,其程序啟動時并不檢查這些動態(tài)庫是否存在。 隱式鏈接是最為常見的,所有的編譯環(huán)境默認都是采用隱式鏈接的方式使用動態(tài)庫。隱式鏈接會在鏈接生成可執(zhí)行程序時就確立依賴關系,在該程序啟動時,操作系統(tǒng)自動會檢查它依賴的動態(tài)庫,并一一加載到該程序的內(nèi)存空間,程序員就不需要操心什么時候加載動態(tài)庫了。比如 VC 編譯環(huán)境,鏈接時使用動態(tài)庫對應的 .lib 文件(包含動態(tài)庫的導出函數(shù)聲明,但沒有實際功能代碼),在 .exe 程序運行前系統(tǒng)會檢查依賴的 .dll,如果找不到某個動態(tài)庫就會出現(xiàn)類似下圖對話框:MinGW 是將動態(tài)庫的導出函數(shù)聲明放在

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論