- 1、本文档共57页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
* * * * * * * * * * * * * * * * 编写这一小节的目的是提醒大家在编程过程中注意编程风格。如果你只是在编写一些小的练习程序,程序只有一两百行长的话,编程风格可能并不重要。然而,如果你和许多人一起进行开发工作,或者,你希望在过一段时间之后,还能够正确理解自己的程序的话,就必须养成良好的编程习惯。在诸多编程习惯当中,编程风格是最重要的一项内容。 * * * * * * * * 编写这一小节的目的是提醒大家在编程过程中注意编程风格。如果你只是在编写一些小的练习程序,程序只有一两百行长的话,编程风格可能并不重要。然而,如果你和许多人一起进行开发工作,或者,你希望在过一段时间之后,还能够正确理解自己的程序的话,就必须养成良好的编程习惯。在诸多编程习惯当中,编程风格是最重要的一项内容。 在内核编程风格中,命名全局变量,就应该用描述性命名方式,例如应该命名“count_active_users()”,而不是“cntusr()”。本地变量应该避免过长。 避免把注释插到函数体内,而写到函数前面,说明其功能,如果这个函数的确很复杂,其中需要有部分注释,可以写些简短的注释来说明那些重要的部分,但是不能过多。 * * * * 其执行效率与一般的编译器相比平均效率要高20%~30% * * * * * * * * * * * * * * * * * * * * 厌倦于手工键入那些常用的命令. 要使你喜好的命令选项一次性准备就绪, 你可以把它们统统写进一个叫vimrc的文件. Vim在启动时会读取该文件 . * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * GNU C 允许使用零长度数组,在定义变长对象的头结构时,这个特性非常有用。 ++++ include/linux/minix_fs.h struct minix_dir_entry { __u16 inode; char name[0]; }; 结构的最后一个元素定义为零长度数组,它不占结构的空间。在标准 C 中则需要定义数组长度为 1,分配时计算对象大小比较复杂。 * * * * * * * * * * * * * * * * 接下来进行的是编译阶段,在这个阶段中,Gcc 首先要检查代码的规范性、是否有语法 错误等,以确定代码的实际要做的工作,在检查无误后,Gcc 把代码翻译成汇编语言。 在这个程序中并没有定义“printf”的函数实现,且在预 编译中包含进的“stdio.h”中也只有该函数的声明,而没有定义函数的实现,那么,是在哪 里实现“printf”函数的呢?最后的答案是:系统把这些函数实现都被做到名为libc.so.6的库 文件中去了,在没有特别指定时,Gcc 会到系统默认的搜索路径“/usr/lib”下进行查找,也 就是链接到libc.so.6库函数中去,这样就能实现函数“printf”了,而这也就是链接的作用。 函数库一般分为静态库和动态库两种。静态库是指编译链接时,把库文件的代码全部加 入到可执行文件中,因此生成的文件比较大,但在运行时也就不再需要库文件了。其后缀名 一般为“.a”。动态库与之相反,在编译链接时并没有把库文件的代码加入到可执行文件中, 而是在程序执行时由运行时链接文件加载库,这样可以节省系统的开销。动态库一般后缀名 为“.so”,如前面所述的libc.so.6就是动态库。Gcc在编译时默认使用动态库。 * * * * * * * * 这些选项中的许多你可能永远都不会用到, 但一些主要的选项将会频繁用到. * * * * Gcc 可以对代码进行优化,它通过编译选项“-On”来控制优化代码的生成,其中 n 是一 个代表优化级别的整数。对于不同版本的Gcc来讲,n的取值范围及其对应的优化效果可能 并不完全相同,比较典型的范围是从0变化到2或3。 不同的优化级别对应不同的优化处理工作。如使用优化选项“-O”主要进行线程跳转 Thread Jump)和延迟退栈(Deferred Stack Pops)两种优化。使用优化选项“-O2”除了完成 所有“-O1”级别的优化之外,同时还要进行一些额外的调整工作,如处理器指令调度等。 选项“-O3”则还包括循环展开和其他一些与处理器特性相关的优化工作。 虽然优化选项可以加速代码的运行速度,但对于调试而言将是一个很大的挑战。因为代 码在经过优化之后,原先在源程序中声明和使用的变量很可能不再使用,控制流也可能会突 然跳转到意外的地方,循环语句也有可能因为循环展开而变得到处都有,所有这些对调试来 讲都将是一场噩梦。所以笔者建议在调试的时候最好不使用任何优化选项,只有当程序在最 终
文档评论(0)