GCC 编译 参数

gcc 编译器常用的命令行参数一览 (转)
 
这些常用的 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
 
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文件夹。

10.-fPIC作用于编译阶段,告诉编译器产生与位置无关代码(Position-Independent Code),
  则产生的代码中,没有绝对地址,全部使用相对地址,故而代码可以被加载器加载到内存的任意
  位置,都可以正确的执行。这正是共享库所要求的,共享库被加载时,在内存的位置不是固定的。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: stack-protector 是 GCC 编译器中的一个参数,它可以在程序中增加栈溢出保护机制。该参数会在编译时在程序的栈帧中增加一个额外的保护字段,以便在运行时检测栈溢出。使用该参数可以有效防止栈溢出漏洞的产生。 ### 回答2: GCC编译参数 stack-protector 是用于在编译时启用堆栈保护机制的选项。堆栈保护是一种防御措施,旨在检测和防止栈溢出攻击。 栈溢出是一种常见的安全漏洞,它发生在栈内存被超出其分配大小的数据覆盖时。攻击者可以通过向缓冲区写入超过其容量的数据来修改目标程序的正常执行流程,并可能导致非法访问、代码执行等安全问题。 启用 stack-protector 参数后,GCC编译时会将堆栈保护代码插入到目标程序中。这些代码会通过检测栈是否被破坏来警告并阻止栈溢出攻击的发生。当检测到栈被破坏时,程序会终止并显示相关错误信息,从而防止攻击者利用栈溢出漏洞执行恶意代码。 具体来说,stack-protector 参数会在栈上分配一个随机的不可覆盖的值,称为"栈冲突保护 canary"。检测发生在函数返回之前或在修改栈上任何变量之前,通过比较 canary 的值是否仍然完好来检测栈是否发生溢出。 使用 stack-protector 参数可以增强目标程序的安全性,防止栈溢出攻击的发生。然而,应该注意,该参数并不能完全解决所有的安全问题,其他安全防御措施如输入验证、内存分配检查等仍然是必要的。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值