Makefile里面的$(MAKE)

您所在的位置:网站首页 make的中文意思是啥 Makefile里面的$(MAKE)

Makefile里面的$(MAKE)

2023-11-24 17:36| 来源: 网络整理| 查看: 265

make 定义了很多默认变量,${MAKE} 就是预设的 make 这个命令的名称(或者路径)。

make -p 可以查看所有预定义的变量的当前值。

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

有一个 make 的环境变量叫“MAKECMDGOALS”,这个变量中会存放你所指定的终极目标的列表,如果在命令行上,你没有指定目标,那么,这个变量是空值。这个变量可以让你使用在一些比较特殊的情形下。比如下面的例子:

[html]  view plain copy sources = foo.c bar.c    ifneq ( $(MAKECMDGOALS),clean)    include $(sources:.c=.d)    endif    

基于上面的这个例子,只要我们输入的命令不是“make clean”,那么 makefile 会自动包含“foo.d”和“bar.d”这两个 makefile。  

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

在linux中install命令和cp命令的区别

基本上,在Makefile里会用到install,其他地方会用cp命令。

它们完成同样的任务——拷贝文件,它们之间的区别主要如下:

1、最重要的一点,如果目标文件存在,cp会先清空文件后往里写入新文件,而install则会先删除掉原先的文件然后写入新文件。这是因为往正在 使用的文件中写入内容可能会导致一些问题,比如说写入正在执行的文件可能会失败,比如说往已经在持续写入的文件句柄中写入新文件会产生错误的文件。而使用 install先删除后写入(会生成新的文件句柄)的方式去安装就能避免这些问题了;

2、install命令会恰当地处理文件权限的问题。比如说,install -c会把目标文件的权限设置为rwxr-xr-x;

3、install命令可以打印出更多更合适的debug信息,还会自动处理SElinux上下文的问题。



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3