zoukankan      html  css  js  c++  java
  • gcc命令介绍

    选项

    • -o:指定生成的输出文件;

    • -E:仅执行编译预处理;

    • -S:将代码转换为汇编代码;

    • -wall:显示警告信息;

    • -c:仅执行编译操作,不进行连接操作。

    • -v:输出版本信息

    • -w:不生成所有警告信息

    • -Wall:生成所有警告信息

    • -Wextra:打印出更多的警告信息,比开启 -Wall 还多

    • -pedantic:用于保证代码规范满足ISO C和ISO C++标准, 不允许使用任何扩展以及不满足ISO C和C++的代码, 遵守 -std 选项指定的标准

    • -std=:其后为所使用规定的标准

    • -g:生成调试信息

    • -x:设置语言的类型,可以为c, objective-c,c-header,c++, cpp-output, assemblerassembler-with-cpp.

    实例

    1. gcc test.c将test.c预处理、汇编、编译并链接形成可执行文件。这里未指定输出文件,默认输出为a.out。
    2. gcc test.c -o test.exe将test.c预处理、汇编、编译并链接形成可执行文件test.exe
    3. gcc -E test.c -o test.i将test.c预处理输出test.i文件。
    4. gcc -S test.i将预处理输出文件test.i汇编成test.s文件。
    5. gcc -c test.s将汇编文件test.s编译输出test.o文件。
    6. gcc test.o -o test.exe将编译输出文件test.o链接成最终可执行文件test。
    7. gcc -O1 test.c -o test.exe使用编译优化级别1编译程序。级别为1~3,级别越大优化效果越好,但编译时间越长。

    多文件编译

    1. 方法1
      gcc testfun.c test.c -o test将testfun.c和test.c分别编译后链接成test可执行文件。
    2. 方法2(类似于makefile)
    gcc -c testfun.c                    #将testfun.c编译成testfun.o
    gcc -c test.c                       #将test.c编译成test.o
    gcc -o testfun.o test.o -o test.exe #将testfun.o和test.o链接成test.exe
    

    以上两种方法相比较,第一中方法编译时需要所有文件重新编译,而第二种方法可以只重新编译修改的文件,未修改的文件不用重新编译。

    gcc所遵循的部分约定规则:

    • .c为后缀的文件,C语言源代码文件;
    • .a为后缀的文件,是由目标文件构成的档案库文件;
    • .C,.cc或.cpp 为后缀的文件,是C++源代码文件且必须要经过预处理;
    • .h为后缀的文件,是程序所包含的头文件;
    • .i 为后缀的文件,是C源代码文件且不应该对其执行预处理;
    • .ii为后缀的文件,是C++源代码文件且不应该对其执行预处理;
    • .m为后缀的文件,是Objective-C源代码文件;
    • .mm为后缀的文件,是Objective-C++源代码文件;
    • .o为后缀的文件,是编译后的目标文件;
    • .s为后缀的文件,是汇编语言源代码文件;
    • .S为后缀的文件,是经过预编译的汇编语言源代码文件。
  • 相关阅读:
    POJ1028 Web Navigation【堆栈+模拟】
    UVa10276 HDU1329 ZOJ1239 Hanoi Tower Troubles Again!【递推函数+打表】
    UVALive5369 UVa732 HDU1515 ZOJ1004 Anagrams by Stack【DFS+堆栈】
    HDU5776 sum【前缀和+模除】
    POJ1844 Sum【水题+数学题】
    AOJ0558 Cheese【BFS】
    POJ3009 Curling 2.0【DFS】
    HDU1163 Eddy's digital Roots(解法二)【快速模幂+九余数定理】
    HDU1210 Eddy's 洗牌问题【递推函数+模拟】
    Vijos P1571 笨笨的导弹攻击【最长上升子序列+DP】
  • 原文地址:https://www.cnblogs.com/h-hg/p/8366072.html
Copyright © 2011-2022 走看看