一、初步认识make和Makefile
我们首先需要知道的是,make是一个命令,Makefile是一个文件,Makefile中包含了依赖关系和依赖方法。
从上面的文件以及指令中我们可以看到,我们可以在Makefile文件中写入依赖关系以及对应的依赖方法,Makefile文件保存退出后,在命令行中执行make,就可以自动帮我们执行依赖关系中的方法(如上所示,可以形成mybin可执行文件)。但需要注意的是,Makefile文件名不要写错。
make和Makefile形成目标文件的时候,默认是执行第一条依赖方法,如果要执行第二或者第三条依赖方法,需要再make后加上依赖关系名。
二、补充:Linux中的三个时间
access:访问该文件的时间,access时间可能不是实时更新的
modify:最后一次修改该文件内容的时间
change:最后一次修改该文件属性的时间
三、 make和Makefile语法的认识
.PHONY 目标文件:修饰目标文件,使之成为一个伪目标,其对应的依赖方法在每次调用时总是被执行,但该语法一般只推荐对清除的依赖方法使用,不推荐对一般的编译依赖方法使用。
在Makefile中,可以用$@表示目标文件,$^表示源文件,效果和写成目标文件和源文件是一样的。
这种替换方法其实可以引申到Makefile中一般的变量替换,这其实有点类似于C/C++中的宏替换。
四、基于make和Makefile的进度条代码的实现
//Makefile
processbar:processbar.c main.cgcc -o $@ $^
.PHONY:clean
clean:rm -f processbar
//processbar.h
#include <stdio.h>#define NUM 103
#define Body '='
#define Head '>'typedef void (*callback_t)(double);//回调函数void process_flush(double rate);
//processbar.c
#include "processbar.h"
#include <string.h>
#include <unistd.h>const char *lable="|/-\\";char buffer[NUM] = {0};
void process_flush(double rate)
{static int cnt = 0;int n = strlen(lable);if(rate <= 1.0){buffer[0] = Head;}printf("[%-100s][%.1f%%][%c]\r", buffer, rate, lable[cnt%n]);//buffer为进度条,rate为比率,lable为旋转光标fflush(stdout);//\r为回车,不会将缓冲区的内容自动刷新到屏幕上,需要用fflush刷新buffer[(int)rate] = Body;if((int)rate + 1 < 100){buffer[(int)(rate+1)] = Head;}if(rate >= 100.0){printf("\n");}cnt++;cnt %= n;
}
//main.c
#include "processbar.h"
#include <time.h>
#include <stdlib.h>
#include <unistd.h>#define FILESIZE 1024*1024*1024void download(callback_t cd) // 回调函数
{srand(time(NULL));int total = FILESIZE;while(total){usleep(10000);//下载int one = rand() % (1024*1024*10);total -= one;if(total < 0){total = 0;}//当前进度int download = FILESIZE - total;double rate = (download*1.0/(FILESIZE))*100.0;cd(rate);//调用回调函数打印}
}int main()
{download(process_flush);return 0;
}
运行结果如下: