LINUX gcc/g++编译命令

匿名 (未验证) 提交于 2019-12-02 21:59:42
1. gcc -E source_file.c
-E,只执行到预编译。直接输出预编译结果。


-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的可执行文件。


-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/





cpp1.h
  1. #include<iostream>
  2. usingnamespace
  3. void
#include<iostream> using namespace std; void print1(); 


cpp2.h
  1. #include<iostream>
  2. usingnamespace
  3. void
#include<iostream> using namespace std; void print2(); 

cpp1.cpp
  1. #include"cpp1.h"
  2. void
  3. cout<<
#include"cpp1.h" void print1() { cout<<"this is cpp1"<<endl; } 

cpp2.cpp
  1. #include"cpp2.h"
  2. void
  3. cout<<
#include"cpp2.h" void print2() { cout<<"this is cpp2"<<endl; } 

  1. #include<iostream>
  2. #include"opencv2/highgui/highgui.hpp"
  3. #include"cpp1.h"
  4. #include"cpp2.h"
  5. usingnamespace
  6. usingnamespace
  7. int
  8. "cones.png"
  9. "cones"
main.cpp #include<iostream> #include"opencv2/highgui/highgui.hpp" #include"cpp1.h" #include"cpp2.h" using namespace std; using namespace cv; int main() {   Mat a=imread("cones.png",0); print1(); print2();   imshow("cones",a); cvWaitKey(0);  }

用指令编译:

思路就是分别把除了main函数所在的cpp都编译成目标文件,然后再和maincpp链接

总结:

其实现在我们可以写一个shell来管理这些编译指令

~learn_cmake2/

---build.sh

  1. '/home/baohua/learnlinux/learn_cmake2/include'
  2. '/home/baohua/learnlinux/learn_cmake2/include'
cd .. cd src g++ -c cpp1.cpp -I'/home/baohua/learnlinux/learn_cmake2/include' g++ -c cpp2.cpp -I'/home/baohua/learnlinux/learn_cmake2/include' 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 ./output

运行结果:


易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!