Linux程序编译速度提高方法

Linux开源程序编译往往会需要较长时间,多核处理器的应用可以大大缩短编译所需要的时间。

 

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

 

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

[xhtml] view plain copy
  1. -j [N], --jobs[=N]          Allow N jobs at once; infinite jobs with no arg.  

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

[xhtml] view plain copy
  1. make -j 2  

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

 

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

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

[c-sharp] view plain copy
  1. 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) $@

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值