Linux下的自动化构建工具之make/makefile的用法详解
脚本之家 / 编程助手:解决程序员“几乎”所有问题!
脚本之家官方知识库 → 点击立即使用
一、make和makefile的区别
make是一个命令,makefile是一个文件。
二、makefile的原理
1、make的原理详解
每次生成可执行文件时需要输入一长串的gcc········指令是不是感觉很麻烦?makefile存在的意义是为了项目的构建。需要表明依赖关系和依赖方法。
2、临时文件的清理
.PHONY表示被该关键字修饰的对象是一个伪目标。(该伪目标总是可被执行)
我们在编写完makefile后,make一下,就能生成对应的可执行程序。如果依赖的文件列表没有发生修改,gcc通过判断mycode.c的Modify time早于mycode的Modify time,说明依赖文件列表没有修改,那么再次make将会失败;反之,重新编译将会成功。
不过多次make clean却不会失败,因为clean被.PHONY修饰,变成了一个伪目标,所以clean总是可被执行。
3、文件的三个时间
1 2 3 4 5 6 7 8 9 | [root@VM-4-11-centos ~] # stat 106/text.c File: ‘106 /text .c' Size: 0 Blocks: 0 IO Block: 4096 regular empty file Device: fd01h /64769d Inode: 658416 Links: 1 Access: (0644 /-rw-r--r-- ) Uid: ( 0/ root) Gid: ( 0/ root) Access: 2022-09-17 21:13:21.098656019 +0800 // 最近访问 Modify: 2022-09-17 21:13:21.098656019 +0800 // 最近修改 Change: 2022-09-17 21:13:21.098656019 +0800 // 最近改动 Birth: - |
1、读取文件时,Access time被改变,而Modify、Change time不会被改变(为防止文件被频繁访问修改Access time,优化为多次访问才修改一次该时间)
2、修改文件时,三个时间都会被改变
3、修改属性时,Change time被改变,而Access、Modify time不会被改变
三、makefile的推导规则
makefile会自己逐步寻找依赖文件列表,如果没找到对于依赖文件,将会继续向下寻找该依赖文件的依赖方法。
四、实现一个进度条
1、缓冲区问题
1 2 3 4 5 6 7 8 9 | #include <stdio.h> #include <unistd.h> int main() { printf ( "hello world\n" ); //如果这里没有\n,程序将会在3秒后执行打印 //fflush(stdout);//fflush会立即刷新缓冲区 sleep(3); return 0; } |
因为\n才会刷新缓冲区(\r等不会),这个程序printf执行完之后,将会休眠3秒,如果没有\n或者fflush手动刷新缓冲区,hello world将会存放至缓冲区,程序结束后才执行打印。
2、实现倒计时程序
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | #include <stdio.h> #include <unistd.h> int main() { int cnt=10; while (cnt) { printf ( "%2d\r" ,cnt); //2d控制刷新两位,\r表示回车 fflush (stdout); //手动刷新缓冲区 sleep(1); --cnt; } return 0; } |
能够实现从10到计时的程序。
3、进度条的实现
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 | //.h文件 #pragma once #include <stdio.h> #include <unistd.h> #include <string.h> #define NUM 101 #define STYLE '*' extern void processOn(); //.c文件 #include "process.h" void processOn() { int cnt=0; char bar[NUM]; memset (bar, '\0' ,NUM); char type[4]={ '|' , '/' , '-' , '\\' }; while (cnt<=100) { //-100表示占据屏幕100个空间并左对齐,%%转义为% printf ( "[%-100s][%d%%][%c]\r" ,bar,cnt,type[cnt%4]); bar[cnt++]=STYLE; fflush (stdout); usleep(50000); } printf ( "\n" ); } |
makefile中不用写头文件,编译器自己会去找。
<>查找方式:直接去库目录下查找,如果找不到,报编译错误;
""查找方式:先去代码所在的路径下查找,如果找不到,再去库目录下查找,如果找不到,报编译错误。
到此这篇关于Linux下的自动化构建工具之make/makefile的用法详解的文章就介绍到这了,更多相关Linux自动化构建工具内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
微信公众号搜索 “ 脚本之家 ” ,选择关注
程序猿的那些事、送书等活动等着你
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若内容造成侵权/违法违规/事实不符,请将相关资料发送至 reterry123@163.com 进行投诉反馈,一经查实,立即处理!
相关文章
Shell中的循环语句for、while、until实例讲解
这篇文章主要介绍了Shell中的循环语句for、while、until实例讲解,简单清晰明了,非常不错的教程,需要的朋友可以参考下2014-06-06
最新评论