make参数详解

 在linux环境下的工作,免不了需要经常编译C/C++源代码,所以make命令是我们经常都会用到的。当然make工具不一定针对C代码,它也可以维护其他各种代码,详见:man make在列举其详细参数之前,我先介绍一下我曾经遇到和总结的两点知识吧。
   1.makefile寻找的顺序(针对GNU make):GNUmakefile、makefile、Makefile 依次寻找;推荐使用Makefile这个文件(因为它通常离README等重要文件更近)。
   2.-j参数,并发执行make的job数量,有-j参数但后面没有跟job数量时,make不会限制同时运行make的job数(尽可能多),特别是对于多核多线程的CPU架构下进行make,-j参数可以有明显的编译构建速度上的提升。下面是一个我做的实验:make了qemu-kvm.git的最新代码。
     2.1 CPU为4核8线程:make 耗时82s, make -j 4 耗时31s, make -j 耗时27s.
     2.2 CPU为单核单线程:make 耗时353, make -j 2 耗时370, make -j 耗时396s。(单核单线程的CPU下用make时最好不用-j参数了,当然这次仅仅是一次测试,也不一定能反映各种真实场景)

下面列举了所有GNU make 3.80版的参数定义。其它版本和产商的make大同小异,不过其它产商的make的具体参数还是请参考各自的产品文档。

“-b”
“-m”
这两个参数的作用是忽略和其它版本make的兼容性。

“-B”
“--always-make”
认为所有的目标都需要更新(重编译)。

“-C <dir>”
“--directory=<dir>”
指定读 取makefile的目录。如果有多个“-C”参数,make的解释是后面的路径以前面的作为相对路径,并以最后的目录作为被指定目录。如:“make –C ~hchen/test –C prog”等价于“make –C ~hchen/test/prog”。

“—debug[=<options>]”
输出make的调试信息。它有几种不同的级别可 供选择,如果没有参数,那就是输出最简单的调试信息。下面是<options>的取值:
    a —— 也就是all,输出所有的调试信息。(会非常的多)
    b —— 也就是basic,只输出简单的调试信息。即输出不需要重编译的目标。
    v —— 也就是verbose,在b选项的级别之上。输出的信息包括哪个makefile被解析,不需要被重编译的依赖文件(或是依赖目标)等。
    i —— 也就是implicit,输出所以的隐含规则。
    j —— 也就是jobs,输出执行规则中命令的详细信息,如命令的PID、返回码等。
    m —— 也就是makefile,输出make读取makefile,更新makefile,执行makefile的信息。

“-d”
相当于“--debug=a”。

“-e”
“--environment-overrides”
指明环境变量的值覆盖 makefile中定义的变量的值。

“-f=<file>”
“--file=<file>”
“--makefile=<file>”
指定需要执行的makefile。

“-h”
“--help”
显示帮助信息。

“-i”
“--ignore-errors”
在执行时忽略所有的错误。

“-I <dir>”
“--include-dir=<dir>”
指定一个被包含makefile的搜索目标。可以使用多个“-I”参数来指定多个目录。

“-j [<jobsnum>]”
“--jobs[=<jobsnum>]”
指同时运行命令的个数。如果-j后没有这个jobsnum参数,make运行命令时能运行多少就运行多少。如果有一个以上的“-j”参数,那么仅最后一个“-j”才是有效 的。(注意这个参数在MS-DOS中是无用的)

“-k”
“--keep-going”
出错也不停止运行。如果生成一个目标失败了,那么依赖于其上的目标就不会被执行了。

“-l <load>”
“--load-average[=<load]”
“—max-load[=<load>]”
指定make运行命令的负载。

“-n”
“--just-print”
“--dry-run”
“--recon”
仅输出执行过程中的命令序列,但并不执行。

“-o <file>”
“--old-file=<file>”
“--assume-old=<file>”
不重新生成的指定的<file>,即使这个目标的依赖文件新于它。

“-p”
“--print-data-base”
输出makefile中的所有数据,包括所有的规则和变量。这个参数会让一个 简单的makefile都会输出一堆信息。如果你只是想输出信息而不想执行makefile,你可以使用“make -qp”命令。如果你想查看执行makefile前的预设变量和规则,你可以使用“make –p –f /dev/null”。这个参数输出的信息会包含着你的makefile文件的文件名和行号,所以,用这个参数来调试你的makefile会是很有用的, 特别是当你的环境变量很复杂的时候。

“-q”
“--question”
不 运行命令,也不输出。仅仅是检查所指定的目标是否需要更新。如果是0则说明要更新,如果是2则说明有错误发生。

“-r”
“--no-builtin-rules”
禁止make使用任何隐含规则。

“-R”
“--no-builtin-variabes”
禁止make使用任何作用于变量上的 隐含规则。

“-s”
“--silent”
“--quiet”
在 命令运行时不输出命令的输出。

“-S”
“--no-keep-going”
“--stop”
取消“-k”选项的作用。因为有些时候,make的选项是从环境变量“MAKEFLAGS”中继承下来的。所以你可以在命令行中使用这个参数来让环境变量中 的“-k”选项失效。

“-t”
“--touch”
相当于UNIX的touch命令,只是把目标的修改日期变成最新的,也就是阻止生成目标的命令运行。

“-v”
“--version”
输出make程序的版本、版权等关于make的信息。

“-w”
“--print-directory”
输出运行makefile之前和之后的信息。 这个参数对于跟踪嵌套式调用make时很有用。

“--no-print-directory”
禁止“-w”选项。

“-W <file>”
“--what-if=<file>”
“--new-file=<file>”
“--assume-file=<file>”
假定目标<file>需要更新,如果和“-n”选项使用,那么这个参数会输出该目标更新时的运行动作。如果没有“-n”那么就像运行UNIX的 “touch”命令一样,使得<file>的修改时间为当前时间。

“--warn-undefined-variables”
只要make发现有未定义的变量,那么就输出警告信息


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
`make_blobs` 是一个用于生成聚类数据的函数,可以用于测试聚类算法的效果。下面是 `make_blobs` 中常用参数的说明: - `n_samples`:生成的样本数,默认值为 100。 - `n_features`:生成的特征数,默认值为 2。 - `centers`:指定样本的中心点,可以是整数或数组。当 `centers` 为整数时,表示生成几个中心点;当 `centers` 为数组时,表示指定每个中心点的坐标位置。 - `cluster_std`:每个簇的标准差,表示簇中每个点与该簇中心点的距离。默认值为 1.0。 - `center_box`:指定中心点的范围,当 `centers` 为整数时有效。默认值为 (-10.0, 10.0)。 - `shuffle`:是否打乱样本顺序,默认值为 True。 - `random_state`:随机种子,保证每次生成的样本相同。 例如,以下代码将生成一个包含 300 个样本,共四个中心点的聚类数据集: ```python from sklearn.datasets import make_blobs X, y = make_blobs(n_samples=300, centers=4, cluster_std=0.5, random_state=42) ``` 其中,`X` 是生成的样本特征矩阵,`y` 是每个样本所属的簇的标签。可以使用 `matplotlib` 将生成的数据可视化: ```python import matplotlib.pyplot as plt plt.scatter(X[:, 0], X[:, 1], c=y, cmap='viridis') plt.show() ``` 生成的效果如下图所示: ![make_blobs](https://img-blog.csdn.net/20180801173925140?watermark/2/text/aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L2xlZ2FjeV9wbGFjZV9zaGFyZQ==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/q/75)

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值