Chinaunix首页 | 论坛 | 博客
  • 博客访问: 6320726
  • 博文数量: 2759
  • 博客积分: 1021
  • 博客等级: 中士
  • 技术积分: 4091
  • 用 户 组: 普通用户
  • 注册时间: 2012-03-11 14:14
文章分类

全部博文(2759)

文章存档

2019年(1)

2017年(84)

2016年(196)

2015年(204)

2014年(636)

2013年(1176)

2012年(463)

分类: C/C++

2013-07-17 02:11:41

假设存在下图所示的项目目录结构。

如果存在如下包含头文件的代码,则大多的项目中需要通过“-I foo”和“-I bar”指明两个搜索头文件的目录。

点击(此处)折叠或打开

  1. foo.c
  2. #include "bar.h"

点击(此处)折叠或打开

  1. bar.c
  2. #include "foo.h"


然而,当项目规模很大存在很多的目录时,这种方式将显著地降低项目的编译速度。因为“-I”选项使用得越多,意味着编译每一个C文件时所需进行头文件搜索的目录也越多。


为了避免这一问题,我们可以将代码改为:

点击(此处)折叠或打开

  1. foo.c
  2. #include "bar/bar.h"
点击(此处)折叠或打开
  1. bar.c
  2. #include "foo/foo.h"


如此一来,整个项目只需一个“-I src”选项就行了。


促使我意识到这一问题,是因为前段时间看到Blink开源项目的一封邮件,其中谈到采用上面的第二种方法后,在Windows上编译Blink的速度提高了40%。


本文出自李云的博客,请务必保留此出处:http://blog.chinaunix.net/uid-26470037-id-3805141.html
阅读(395) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~