为了加快代码执行的效率,很多OJ平台都会自动开启O2优化。
在这里我们讲讲到底是怎么优化的。
O0优化
代码语言:javascript复制#pragma GCC optimize(0)
1、把变量分配到寄存器。
2、分析循环的会出现的各种情况,只保留一个退出循环的分支。
3、将没有用的代码删掉。
4、简化表达式和声明。
5、将用inline声明的内联函数变为函数调用。
O1优化
代码语言:javascript复制#pragma GCC optimize(1)
包含O0的各种优化功能,并增加了: 1、在变量赋值时,将数值直接赋给变量而不是给出变量的地址。
2、去掉没有用的变量和表达式。
3、去掉通用的表达式。
O2优化
代码语言:javascript复制#pragma GCC optimize(2)
包含O1的各种优化功能,并增加了:
1、去掉全局通用的子表达式。
2、去掉全局没有用的分配变量和表达式。
3、化解循环。
当只用-O选项时优化器自动进行-O2优化。
O3优化
代码语言:javascript复制#pragma GCC optimize(3)
包含O2的各种优化功能,并增加了:
1、去掉未调用的函数。
2、简化返回值未使用的函数。
3、将小函数进行内嵌调用。
4、对被调用的函数声明进行重新排序,以便被优化的调用方能够找到该函数。
5、完成文件级优化。