O0 O1 O2 O3优化原理

2023-07-30 09:46:20 浏览数 (1)

为了加快代码执行的效率,很多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、完成文件级优化。

0 人点赞