gcc的优化功能

代码优化的目的是改善程序的执行性能。gcc提供的代码优化功能非常强大,它通过参数-On来控制优化代码的生成,其中n为优化级别的整数,比较典型的范围是从0变化到2或3(与版本有关)。

编译时通过使用选项-O可以告诉gcc同时减小代码的长度和执行时间,其效果等价于-O1,在这一级别上能够进行的优化类型虽然取决于目标处理器,但一般都会包括线程跳转和延迟退栈两种优化。选项-O2除了完成所有-O1级别的优化外,同时还要进行一些额外的调整工作,如处理器指令调度等。选项O3除了完成所有-O2级别的优化外,还包括循环展开和其他一些与处理器特性相关的优化工作。数字越大优化的等级越高,程序的运行速度更快。一般采用-O2选项,因为它在优化长度、编译时间和代码大小之间取得了一个比较理想的平衡点。

借助Linuxtime命令,可以大致统计出该程序在运行时所需要的时间,注意此时最好退出其它程序。

[root@localhost work]# gcc -Wall hello.c -o hello

[root@localhost work]# time ./hello

hello world!

real  0m0.011s

user 0m0.000s

sys   0m0.002s

//优化如下:

[root@localhost work]# gcc -Wall -O hello.c -o hello

[root@localhost work]# time ./hello

 

[root@localhost work]# gcc -Wall -O1 hello.c -o hello

[root@localhost work]# time ./hello

 

[root@localhost work]# gcc -Wall -O2 hello.c -o hello

[root@localhost work]# time ./hello

 

[root@localhost work]# gcc -Wall -O3 hello.c -o hello

[root@localhost work]# time ./hello

real:进程总的执行时间,它和系统负载有关(包括了进程调度,切换的时间)

user:被测量的进程中用户指令的执行时间(CPU的运行,计算等)

sys:被测量的进程中内核代用户指令执行的时间,user和sys的和被称为CPU时间(系统调用消耗的时间)。

注意:尽管gcc的代码优化功能很强大,但还是要求能够手工编写出高质量的代码(很重要),如果自己编写的代码简洁,逻辑性强,则编译器就不会做更多的工作,甚至不需要进行优化。而且在一些场合中不允许对代码进行优化:程序开发的时候,优化等级越高,消耗在编译的时间上也就越长,因此开发的时候不建议对代码进行优化,只有软件开发结束的时候,才考虑对最终代码进行优化。跟踪调试的时候,也不建议对代码进行优化,因为优化可能会使某些代码被删除或改写,或者重组,从而使跟踪和调试变得异常困难。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/385444.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

gcc编译多个源代码文件的过程(引出makefile)

由foo1.c foo2.c foo3.c 3个源文件组成的源程序生成最终的可执行程序foo的命令: gcc foo1.c foo2.c foo3.c -o foo 如果处理的源文件不止一个,则gcc会依次对每个文件进行预处理、编译、汇编,最后将所有的目标代码和库文件进行,链…

观擦者模式

/********************************************************************created: 2006/07/20filename: Observer.hauthor: 李创http://www.cppblog.com/converse/purpose: Observer模式的演示代码 *********************************************************************/…

程序的装入和链接

注:这是本人学习汤小丹等编写的计算机操作系统(西安电子科技大学出版社)的学习笔记,因此许多引用来源于此书,在正文中就不注明了! 程序在运行前需要经过以下步骤:编译程序对源程序进行编译生成…

内存对齐

1. 对齐原则: 数据成员对齐规则:结构(struct)(或联合(union))的数据成员,第一个数据成员放在offset为0的地方,以后每个数据成员的对齐按照#pragma pack指定的数值和这个数据成员自身长度中,比较小的那个进行。结构(或…

1006. 换个格式输出整数 (15)

让我们用字母B来表示“百”、字母S表示“十”&#xff0c;用“12...n”来表示个位数字n&#xff08;<10&#xff09;&#xff0c;换个格式来输出任一个不超过3位的正整数。例如234应该被输出为BBSSS1234&#xff0c;因为它有2个“百”、3个“十”、以及个位的4。 输入格式&a…

静态库的制作和使用

Linux下的静态库为lib*.a格式的二进制文件&#xff08;目标文件&#xff09;&#xff0c;对应于Windows下的.lib格式的文件。 &#xff08;1&#xff09;命名规则 lib库名字 .a libMytest.a &#xff0c;则库名字为mytest。下面以具体的代码为例介绍如何制作静态库。 //mai…

IO多路复用之select

int select(int nfds, fd_set *readfds, fd_set *writefds,fd_set *exceptfds, struct timeval *timeout); 分析&#xff1a; nfds: 监控的文件描述符集里最大文件描述符加1&#xff0c;因为此参数会告诉内核检测前多少个文件描述符的状态 readfds&#xff1a; …

1031. 查验身份证(15)

一个合法的身份证号码由17位地区、日期编号和顺序编号加1位校验码组成。校验码的计算规则如下&#xff1a; 首先对前17位数字加权求和&#xff0c;权重分配为&#xff1a;{7&#xff0c;9&#xff0c;10&#xff0c;5&#xff0c;8&#xff0c;4&#xff0c;2&#xff0c;1&…

虚拟地址空间

对于每一个进程都会对应一个虚拟地址空间&#xff0c;对于32位的操作系统&#xff08;其指令的位数最大为32位&#xff0c;因此地址码最多32位&#xff09;&#xff0c;虚拟地址空间的大小为B即0~4GB的虚拟地址空间&#xff0c;其中内核空间为1GB&#xff0c;如下所示&#xff…

Leecode 69. x 的平方根

实现 int sqrt(int x) 函数。 计算并返回 x 的平方根&#xff0c;其中 x 是非负整数。 由于返回类型是整数&#xff0c;结果只保留整数的部分&#xff0c;小数部分将被舍去。 示例 1: 输入: 4 输出: 2 示例 2: 输入: 8 输出: 2 说明: 8 的平方根是 2.82842..., 由于返回类…

1002. 写出这个数 (20)

读入一个自然数n&#xff0c;计算其各位数字之和&#xff0c;用汉语拼音写出和的每一位数字。 输入格式&#xff1a;每个测试输入包含1个测试用例&#xff0c;即给出自然数n的值。这里保证n小于10100。 输出格式&#xff1a;在一行内输出n的各位数字之和的每一位&#xff0c;拼…

C/C++中NULL指针

先谈一下C/C的强制类型转换Type cast。与强制类型转换相对应的是自动类型转换。或者强制类型转换叫显示类型转换&#xff0c;自动类型转换叫隐式类型转换。自动类型转换会在赋值运算、混合运算、参数传递、返回函数返回值、格式化输出时且当类型出现不一致时发生&#xff0c;转…

1009. 说反话 (20)

给定一句英语&#xff0c;要求你编写程序&#xff0c;将句中所有单词的顺序颠倒输出。 输入格式&#xff1a;测试输入包含一个测试用例&#xff0c;在一行内给出总长度不超过80的字符串。字符串由若干单词和若干空格组成&#xff0c;其中单词是由英文字母&#xff08;大小写有区…

动态库(共享库)的制作和使用

Linux下的动态库为lib*.so格式的二进制文件&#xff08;目标文件&#xff09;&#xff0c;对应于Windows下的.dll格式的文件。 &#xff08;1&#xff09;命名规则 lib库名.so &#xff08;2&#xff09;动态库的制作 1&#xff09;生成与位置无关的代码&#xff08;.o&…

孤儿进程、僵尸进进程

一、儿进程与僵尸进程 1、基本概念 我们知道在unix/linux中&#xff0c;正常情况下&#xff0c;子进程是通过父进程创建的&#xff0c;子进程在创建新的进程。子进程的结束和父进程的运行是一个异步过程,即父进程永远无法预测子进程 到底什么时候结束。 当一个 进程完成它的工…

管道 -pipe

gcc编译器将源代码编译成可执行程序的过程中&#xff0c;需要经过许多中间步骤&#xff08;预处理、编译、汇编、链接&#xff09;&#xff0c;这些过程实际上是由不同的程序来负责完成的&#xff08;/usr/bin/gcc、cpp、ccl、as和ld等&#xff09;。在这个过程的每一个阶段中&…

gdb调试器(一)

在默认情况下&#xff0c;gcc在编译时不会把调试符号插入到最终生成的二进制代码&#xff08;机器代码&#xff09;中&#xff0c;因为这样会急剧增加可执行程序的大小。如果需要在编译时生成调试符号的信息&#xff0c;则可以采用-g或-ggdb参数。 gcc在产生调试信息时&#x…

1048. 数字加密(20)

本题要求实现一种数字加密方法。首先固定一个加密用正整数A&#xff0c;对任一正整数B&#xff0c;将其每1位数字与A的对应位置上的数字进行以下运算&#xff1a;对奇数位&#xff0c;对应位的数字相加后对13取余——这里用J代表10、Q代表11、K代表12&#xff1b;对偶数位&…

网络编程套接字API

uint32_t htonl(uint32_t hostlong); uint16_t htons(uint16_t hostshort); uint32_t ntohl(uint32_t netlong); uint16_t ntohs(uint16_t netshort);int inet_pton(int family, const char *strptr, void *addrptr); 分析&#xff1a; 第一个参数可以是AF_INET或AF_INET6&am…

gdb调试器(二)

Linux下的gdb&#xff08;GNU Debugger&#xff09;是一个用来调试C、C程序的调试器&#xff08;命令行方式的调试器&#xff09;&#xff0c;能够在程序运行期间观察程序的内部结构和内存的使用情况。程序员也可以使用gdb来跟踪程序中的错误&#xff0c;从而减少程序员的工作量…