您的位置:首页 > 运维架构 > Linux

Linux程序编译速度提高方法

2016-01-14 15:06 756 查看
Linux开源程序编译往往会需要较长时间,多核处理器的应用可以大大缩短编译所需要的时间。

 

默认情况下,make并没有将多核处理器的性能发挥到极限。相反,它只使用了其中一个核心。

 

make的-j参数可以使make进行并行编译。make该参数的帮助如下:

[xhtml]
view plaincopy

-j 
, --jobs[=N]          Allow N jobs at once; infinite jobs with no arg.  

意思是在同一时间可以进行并行编译的任务数。比如说如下命令:

[xhtml]
view plaincopy

make -j 2  

则是告诉处理器同时处理两个编译任务。

 

而如果-j后不跟任何数字,则不限制处理器并行编译的任务数。

我的处理器为8核心CPU,我直接运行:

[c-sharp]
view plaincopy

make -j  

编译boost库的时间大大缩短。

 

注意:make -j命令并不是任何情况下都可以用的,在存在编译依赖的情况下,单核编译还是一种比较稳妥的方案。

---------------------------------------我是分割线-------------------------------------

make的任务数能自动设置成CPU的数量。调查了一下它是怎么做的。

linux/tools/perf/Makefile
#
# Do a parallel build with multiple jobs, based on the number
#of CPUs online
# in this system: 'make -j8' on a 8-CPU system, etc.
#
# (To override it, run 'make JOBS=1' and similar.)
#
ifeq ($(JOBS),)
JOBS := $(shell grep -c ^processor /proc/cpuinfo 2>/dev/null)
ifeq ($(JOBS),)
JOBS := 1
endif
endif


这种计算了/proc/cpuinfo以processor开头的行的数量。

这里不使用wc命令来计算匹配的行数,而是用grep -c来获取。

这里JOBS是CPU的个数,用这个变量在子进程中使用make命令。

$(MAKE) -f Makefile.perf --no-print-directory -j$(JOBS)
O=$(FULL_O) $(SET_DEBUG) $@
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: