詳解 linux c++的編譯器g++的基本使用
linux c++的編譯器g++基本使用
g++是 linux下c++的編譯器,在執(zhí)行編譯工作的時候,總共需要4步
1.預處理,生成.i的文件
2.將預處理后的文件不轉(zhuǎn)換成匯編語言,生成文件.s
3.有匯編變?yōu)槟繕舜a(機器代碼)生成.o的文件
4.連接目標代碼,生成可執(zhí)行程序
g++ 編譯c++經(jīng)常使用的參數(shù):
-c
只編譯,不連接。例如: g++ -c helloworld.cpp
只生成helloworld.o不連接
-o
指定輸出文件名。例如:g++ -c helloworld.cpp -o abc.o
默認是生成helloworld.o,用-o abc.o以后,就生成的是abc.o
-I
附加一個包函頭文件的路徑。例如:g++ helloworld.cpp -I"/usr/helloworld/include"
-l
小的L, 附一個庫,例如要使用libabc.so 就g++ helloworld.cpp -labc
-L
添加一個庫的路徑,例如 g++ hello.cpp -L"/usr/hello/lib" -labc
-shared
生成動態(tài)庫文件,例如: g++ -shared hellp.cpp -o libhello.so
調(diào)用動態(tài)庫的時候有幾個問題會經(jīng)常碰到,有時,明明已經(jīng)將庫的頭文件所在目錄通過include進來了,庫所在文件通過 “-L”參數(shù)引導,并指定了“-l”的庫名,但通過ldd命令察看時,就是死活找不到你指定鏈接的so文件。其實編譯鏈接上了共享庫不代表執(zhí)行時可以找到。所以“-L”什么的對執(zhí)行沒有用,你需要指明共享庫的路徑。方法有三個:
a.修改 LD_LIBRARY_PATH,指明共享庫的路徑。LD_LIBRARY_PATH:這個環(huán)境變量指示動態(tài)連接器可以裝載動態(tài)庫的路徑。在終端下使用如下命令:
[root@localhost sharelib]# export LD_LIBRARY_PATH = . [root@localhost sharelib]# export LD_LIBRARY_PATH = your lib dir export
b.通過/etc/ld.so.conf文件來指定動態(tài)庫的目錄。然后運行l(wèi)dconfig命令更新搜索共享庫的路徑。通常這個做法就可以解決庫無法鏈接的問題并且一勞永逸。
c.或者把庫文件拷貝到/lib下,然后ldconfig就ok了。這個方法有的取巧,且破壞原庫文件的純潔性,不應是首選方法。
修改/etc/ld.so.conf文件,然后調(diào)用 /sbin/ldconfig需要有root權限,如果沒有root權限,那么只能采用輸出LD_LIBRARY_PATH的方法了。
linux下文件的類型是不依賴于其后綴名的,但一般來講:
.o,是目標文件,相當于windows中的.obj文件
.so 為共享庫,是shared object,用于動態(tài)連接的,和dll差不多
.a為靜態(tài)庫,是好多個.o合在一起,用于靜態(tài)連接
.la為libtool自動生成的一些共享庫,主要記錄了一些配置信息。
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關文章
C/C++中數(shù)據(jù)類型轉(zhuǎn)換詳解及其作用介紹
這篇文章主要介紹了C/C++中數(shù)據(jù)類型轉(zhuǎn)換詳解及其作用,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-09-09C++中std::ios_base::floatfield報錯已解決
在C++編程中,設置浮點數(shù)輸出格式時可能遇到std::ios_base::floatfield錯誤,解決方法包括使用正確的格式化標志組合,避免沖突的格式化設置,以及檢查流狀態(tài)標志是否正確,通過這些方法可以有效避免浮點數(shù)格式化錯誤,并確保輸出精確2024-09-09