Linux开源程序编译往往会需要较长时间,多核处理器的应用可以大大缩短编译所需要的时间。
默认情况下,make并没有将多核处理器的性能发挥到极限。相反,它只使用了其中一个核心。
make的-j参数可以使make进行并行编译。make该参数的帮助如下:
- -j [N], --jobs[=N] Allow N jobs at once; infinite jobs with no arg.
意思是在同一时间可以进行并行编译的任务数。比如说如下命令:
- make -j 2
则是告诉处理器同时处理两个编译任务。
而如果-j后不跟任何数字,则不限制处理器并行编译的任务数。
我的处理器为8核心CPU,我直接运行:
- make -j
编译boost库的时间大大缩短。
注意:make -j命令并不是任何情况下都可以用的,在存在编译依赖的情况下,单核编译还是一种比较稳妥的方案。
---------------------------------------我是分割线-------------------------------------
make的任务数能自动设置成CPU的数量。调查了一下它是怎么做的。
#
# 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) $@