gcc 命令詳解


1. gcc -E source_file.c
-E,只執行到預編譯。直接輸出預編譯結果。

2. gcc -S source_file.c 
-S,只執行到源代碼到匯編代碼的轉換,輸出匯編代碼。

3. gcc -c source_file.c
-c,只執行到編譯,輸出目標文件。

4. gcc (-E/S/c/) source_file.c -o output_filename
-o, 指定輸出文件名,可以配合以上三種標簽使用。
-o 參數可以被省略。這種情況下編譯器將使用以下默認名稱輸出:
-E:預編譯結果將被輸出到標准輸出端口(通常是顯示器)
-S:生成名為source_file.s的匯編代碼
-c:生成名為source_file.o的目標文件。
無標簽情況:生成名為a.out的可執行文件。

5. gcc -g source_file.c 
-g,生成供調試用的可執行文件,可以在gdb中運行。由於文件中包含了調試信息因此運行效率很低,且文件也大不少。
這里可以用strip命令重新將文件中debug信息刪除。這是會發現生成的文件甚至比正常編譯的輸出更小了,這是因為strip把原先正常編譯中的一些額外信息(如函數名之類)也刪除了。用法為 strip a.out

6. gcc -s source_file.c
-s, 直接生成與運用strip同樣效果的可執行文件(刪除了所有符號信息)。

7. gcc -O source_file.c
-O(大寫的字母O),編譯器對代碼進行自動優化編譯,輸出效率更高的可執行文件。
-O 后面還可以跟上數字指定優化級別,如:
gcc -O2 source_file.c
數字越大,越加優化。但是通常情況下,自動的東西都不是太聰明,太大的優化級別可能會使生成的文件產生一系列的bug。一般可選擇2;3會有一定風險。

8. gcc -Wall source_file.c
-W,在編譯中開啟一些額外的警告(warning)信息。-Wall,將所有的警告信息全開。

9. gcc source_file.c -L/path/to/lib -lxxx -I/path/to/include
-l, 指定所使用到的函數庫,本例中鏈接器會嘗試鏈接名為libxxx.a的函數庫。
-L,指定函數庫所在的文件夾,本例中鏈接器會嘗試搜索/path/to/lib文件夾。

-I, 指定頭文件所在的文件夾,本例中預編譯器會嘗試搜索/path/to/include文件夾。

下面我們實際試試用命令行怎么操作。

 

   首先寫好測試代碼

工程目錄            

~learn_cmake2/

                           +src/

                            |            |--cpp1.cpp

 

                           |            |--cpp2.cpp

                           |            |---main.cpp

                           +include/

                            |             |---cpp1.h

                            |             |---cpp2.h

                            +build/

                            +CMakeList

 

 

[cpp]  view plain  copy
 
  1. cpp1.h  
[cpp]  view plain  copy
 
  1. #include<iostream>  
  2. using namespace std;  
  3. void print1();  

 

 

[cpp]  view plain  copy
 
  1. cpp2.h  
[cpp]  view plain  copy
 
  1. #include<iostream>  
  2. using namespace std;  
  3. void print2();  

 

[cpp]  view plain  copy
 
  1. cpp1.cpp  
[cpp]  view plain  copy
 
  1. #include"cpp1.h"  
  2. void print1()  
  3. {  
  4. cout<<"this is cpp1"<<endl;  
  5. }  

 

[cpp]  view plain  copy
 
  1. cpp2.cpp  
[cpp]  view plain  copy
 
  1. #include"cpp2.h"  
  2. void print2()  
  3. {  
  4. cout<<"this is cpp2"<<endl;  
  5. }  

 

[cpp]  view plain  copy
 
  1. main.cpp  
  2. #include<iostream>  
  3. #include"opencv2/highgui/highgui.hpp"  
  4. #include"cpp1.h"  
  5. #include"cpp2.h"  
  6. using namespace std;  
  7. using namespace cv;  
  8. int main()  
  9. {  
  10.   Mat a=imread("cones.png",0);  
  11. print1();  
  12. print2();  
  13.   imshow("cones",a);  
  14. cvWaitKey(0);  
  15.   
  16. }  

用指令編譯:

思路就是分別把除了main函數所在的cpp都編譯成目標文件,然后再和maincpp鏈接

 
        

總結:  無論我們采用哪種方式編譯,總需要告訴編譯器我們要編譯哪些cpp,這些cpp用到頭文件(路徑)在哪里。這些cpp用到的第三方庫是什么(庫文件名字),庫在哪里(庫路徑),庫給我們的接口在哪里(庫頭頭文件路徑,我們在寫cpp時通過include頭文件,用接口調用相應的庫實現)

 

其實現在我們可以寫一個shell來管理這些編譯指令

 

~learn_cmake2/

                           +src/

                            |            |--cpp1.cpp

 

                           |            |--cpp2.cpp

                           |            |---main.cpp

 

                           +include/

                            |             |---cpp1.h

                            |             |---cpp2.h

                            +build/

                            |             |---build.sh

                            +CMakeList

---build.sh

[cpp]  view plain  copy
 
  1. cd ..  
  2. cd src  
  3. g++ -c cpp1.cpp -I'/home/baohua/learnlinux/learn_cmake2/include'  
  4. g++ -c cpp2.cpp -I'/home/baohua/learnlinux/learn_cmake2/include'  
  5. g++ main.cpp -o output -L/usr/lib  -lopencv_highgui  -lopencv_core cpp1.o cpp2.o -I/home/baohua/learnlinux/learn_cmake2/include -I/usr/local/include  
  6. ./output  

運行結果:

 

 

 
        

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM