调用gcc gcc命令大全

【最佳答案】gcc使用break或者b命令,添加断点调用gcc2在终端中输入 gcc 文件名 -o 目标文件名然后 ./目标文件名就行了,没有目标文件名,自动存为 a执行 ./a 就行了 。在使用Gcc编译器的时候,我们必须给出一系列必要的调用参数和gcc命令大全1gcc使用break或者b命令,添加断点
调用gcc2在终端中输入 gcc 文件名 -o 目标文件名然后 ./目标文件名就行了,没有目标文件名,自动存为 a执行 ./a 就行了 。在使用Gcc编译器的时候,我们必须给出一系列必要的调用参数和文件名称 。GCC编译器的调用参数大约有100多个,其中多数参数我们可能根本就用不到,这里只介绍其中最基本、最常用的参数 。GCC最基本的用法是∶gcc [options] [filenames]其中options就是编译器所需要的参数,filenames给出相关的文件名称 。-c,只编译,不连接成为可执行文件,编译器只是由输入的.c等源代码文件生成.o为后缀的目标文件,通常用于编译不包含主程序的子程序文件 。-o output_filename,确定输出文件的名称为output_filename,同时这个名称不能和源文件同名 。如果不给出这个选项,gcc就给出预设的可执行文件a.out 。-g,产生符号调试工具(GNU的gdb)所必要的符号资讯,要想对源代码进行调试,我们就必须加入这个选项 。-O,对程序进行优化编译、连接,采用这个选项,整个源代码会在编译、连接过程中进行优化处理,这样产生的可执行文件的执行效率可以提高,但是,编译、连接的速度就相应地要慢一些 。-O2,比-O更好的优化编译、连接,当然整个编译、连接过程会更慢 。-Idirname,将dirname所指出的目录加入到程序头文件目录列表中,是在预编译过程中使用的参数 。C程序中的头文件包含两种情况∶A)#include B)#include “myinc.h”其中,A类使用尖括号(< >),B类使用双引号(“ ”) 。对于A类,预处理程序cpp在系统预设包含文件目录(如/usr/include)中搜寻相应的文件,而B类,预处理程序在目标文件的文件夹内搜索相应文件 。GCC执行过程示例示例代码 a.c:#includeint main(){printf("hello\n");}预编译过程:这个过程处理宏定义和include,并做语法检查 。可以看到预编译后,代码从5行扩展到了910行 。gcc -E a.c -o a.icat a.c | wc -l5cat a.i | wc -l910编译过程:这个阶段,生成汇编代码 。gcc -S a.i -o a.scat a.s | wc -l59汇编过程:这个阶段,生成目标代码 。此过程生成ELF格式的目标代码 。gcc -c a.s -o a.ofile a.oa.o: ELF 64-bit LSB relocatable, AMD x86-64, version 1 (SYSV), not stripped链接过程:链接过程 。生成可执行代码 。链接分为两种,一种是静态链接,另外一种是动态链接 。使用静态链接的好处是,依赖的动态链接库较少,对动态链接库的版本不会很敏感,具有较好的兼容性;缺点是生成的程序比较大 。使用动态链接的好处是,生成的程序比较小,占用较少的内存 。gcc a.o -o a程序运行:./ahello编辑本段GCC编译简单例子编写如下代码:#includeint main(){printf("hello,world!\n");}执行情况如下:gcc -E hello.c -o hello.igcc -S hello.i -o hello.sgcc -c hello.s -o hello.ogcc hello.c -o hello./hellohello,world!
gcc命令行3计算机右键,高级系统设置,环境变量,在用户变量或者系统变量里面把gcc的路径加进去,注意不要把原来的路径弄没了,不同的路径是用分号分开的 。这样直接在命令行下输入gcc就可以编译当前目录下的文件了 。
gcc命令使用4windows的话,找到你mingw的目录,删除就行,linux下执行包管理器的卸载命令 。
gcc的使用5这些常用的 gcc/g++ 命令行参数,你都知道么?
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