g++ 小结

本文介绍了GCC的常用编译方式,包括-g用于调试,-c仅编译不链接,-m32指定32位程序。同时,讨论了安全编译选项,如-Wall显示所有警告,-fpermissive降低不一致代码的错误级别,以及关于NX、Canary、RELRO和PIE等安全特性如何启用或禁用。确保程序在编译过程中考虑安全性。
摘要由CSDN通过智能技术生成

1.常用编译方式

例:# g++ main.cpp -o main_x64
采用 g++ [文件名] -o [可执行文件名] 的格式。

-g 添加gdb调试选项
-c 只编译不链接,只生成目标文件
-m32编译32位程序

编译前安装相关依赖
# dpkg --add-architecture i386
# apt update
# apt install gcc-multilib g++-multilib

-lcrypto 链接crypto密码类库

x64架构,编译前安装64位的依赖# apt install libssl-dev
x86架构,编译前安装32位的依赖# apt install libssl-dev:i386

2.安全编译选项:

-Wall 编译后显示所有警告
-fpermissive 将不一致代码的诊断从错误降级为警告

NX:

-z execstack 禁用
-z noexecstack 启用,默认是启用的

Canary:

-fno-stack-protector 禁用
-fstack-protector 启用
-fstack-protector-all 全启用

RELRO:

-z norelro 禁用
-z lazy 部分启用
-z now 全启用

PIE:

-no-pie 禁用
-pie 启用
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值