ヾ(๑╹◡╹)ノ” 人总要为过去的懒惰而付出代价ヾ(๑╹◡╹)ノ”
一、Linux项目自动化构建工具–make/Makefile
1.1 背景
- 一个工程中的源文件不计数,其按类型、功能、模块分别放在若干个目录中,makefile定义了一系列的规则来指定,哪些文件需要先编译,哪些文件需要后编译,哪些文件需要重新编译,甚至于进行更复杂的功能操作
- makefile带来的好处就是——“自动化编译”,一旦写好,只需要一个make命令,整个工程完全自动编译,极大的提高了软件开发的效率。
- make是一个命令工具,是一个解释makefile中指令的命令工具,一般来说,大多数的IDE都有这个命令,比如:Delphi的make,Visual C++的nmake,Linux下GNU的make。可见,makefile都成为了一种在工程方面的编译方法。
- make是一条命令,makefile是一个文件,两个搭配使用,完成项目自动化构建。
1.2 实例代码
目的:形成可执行文件【就要有依赖关系和依赖方法】
依赖关系
上面的文件 hello ,它依赖 hello.o
hello.o , 它依赖 hello.s
hello.s , 它依赖 hello.i
hello.i , 它依赖 hello.c
依赖方法
gcc hello.* –option hello.* ,就是与之对应的依赖关系
1.3 原理
多文件的Makefile
三个文件:hello.c hello.h main.c
第一种
第二种
make是如何工作的,在默认的方式下,也就是我们只输入make命令。那么,
- make会在当前目录下找名字叫“Makefile”或“makefile”【大小写都可以】的文件。
- 如果找到,它会找文件中的第一个目标文件(target),并把这个文件作为最终的目标文件。
- 如果hello文件不存在,或是hello所依赖的后面的hello.o文件的文件修改时间要比hello这个文件新(可以用 touch 测试),那么,他就会执行后面所定义的命令来生成hello这个文件。
- 如果hello所依赖的hello.o文件不存在,那么make会在当前文件中找目标为hello.o文件的依赖性,如果找到则再根据那一个规则生成hello.o文件。(这有点像一个堆栈的过程)
- 当然,你的C文件和H文件是存在的啦,于是make会生成 hello.o 文件,然后再用 hello.o 文件声明make的终极任务,也就是执行文件hello了。
- 这就是整个make的依赖性,make会一层又一层地去找文件的依赖关系,直到最终编译出第一个目标文件。
- 在找寻的过程中,如果出现错误,比如最后被依赖的文件找不到,那么make就会直接退出,并报错,而对于所定义的命令的错误,或是编译不成功,make根本不理。
- make只管文件的依赖性,即,如果在我找了依赖关系之后,冒号后面的文件还是不在,那么对不起,我就不工作啦。
1.4 项目清理
- 工程是需要被清理的
- 像clean这种,没有被第一个目标文件直接或间接关联,那么它后面所定义的命令将不会被自动执行,不过,我们可以显示要make执行。即命令——“make clean”,以此来清除所有的目标文件,以便重编译。
- 但是一般我们这种clean的目标文件,我们将它设置为伪目标,用 .PHONY 修饰,伪目标的特性是,总是被执行的。【总是被执行的意思是:无论是目标文件是否新旧,仍然会执行依赖关系的依赖方法】
- .PHONY 可以当做“Makefile的关键字,修饰的是伪目标。 PHONY:伪目标
- 当我们make的时候,默认执行的是形成可执行文件,而不是clean,因为默认执行的是第一个依赖关系的依赖方法。
- 不是.PHONY 修饰,执行方法不是总是被执行的。那么Makefile如何辨别是否是最新的?通过对比源文件和可执行文件的Modify时间 ,来决定是否更新可执行文件。
1.修改内容会引起文件属性发生发生变化。
2.Access访问会发生变化【但是linux访问累积到一定次数才会发生变化,因为访问的次数会非常多,经常发生变化,会影响效率】
二、linux下第一个小程序–进度条
2.1 行缓冲区
#include <stdio.h>
2 #include <unistd.h>
3
4 int main()
5 {
6 printf("hellon");
7 sleep(2);
8 return 0;
9 }
但是hello却是后显示的,因为执行结果在缓冲区,并不是先执行第二条代码。
立马把缓冲区内容显示出来—刷新【行刷新,因为有n,所以够一行,行刷新,所以就显示了出来】
#include <stdio.h>
2 #include <unistd.h>
3
4 int main()
5 {
6 printf("hello");
7 fflush(stdout);
8 sleep(2);
9 return 0;
10 }
换行和回车的概念:
换行:新起一行【光标在上一行最后位置往下移一行。】
回车:光标回到当前行的最开始【仅仅回车r】
换行+回车:新起一行+光标回到当前行的最开始
2.2 进度条
1 #include <stdio.h>
3 #include <unistd.h>
4
5 int main()
6 {
7 int n = 9;
8 while (n)
9 {
10 printf("%dr", n--);
11 fflush(stdout);
12 sleep(1);
13 }
14 return 0;
15 }
1 #include <stdio.h>
2 #include <string.h>
3 #include <unistd.h>//usleep的头文件
4 #define Val 101
5 #define Style '*'
6
7 int main()
8 {
9 char bar[Val];
10 memset(bar, '', sizeof(bar));
11 const char* lable = "|/-\";
12 int i = 0;
13 while(i <= 100)
14 {
15 printf("33[43;34m%-100s33[0m[%d%%][%c]r", bar, i, lable[i%4]);
16 fflush(stdout);
17 usleep(200000);
18 bar[i++] = Style;
19 }
20 printf("n");
21 return 0;
22 }
~
- printf(“33[43;34m%-100s33[0m[%d%%][%c]r”, bar, i, lable[i%4]);
这里的33[背景颜色;字体样色 字符串 33[0m 这是一个固定格式。
注意:test1、clean都要顶格写。
三、git以及gitee
git是什么?
git是一个版本控制器
git什么是版本管理?
第一版,修改完的版本保存【第二版】,保存再次进行改变保存【第三版】……每一个版本都有。就是版本管理
版本控制+网络=git 是一个软件工具 gitee和githup基于git工具,搭建起来的网站
如何使用:
gitee 登录注册
(1)新建仓库,点击复制这个地址
(2)git clone 地址
(3)git commit -m ‘日志’
此时会出现错误:【因为第一次需要配置用户名和邮箱】
提交以下代码即可解决:
git config --global user.email "you@example.com"
git config --global user.name "Your Name"
总结
以上就是今天要讲的内容,本文详细地介绍了Linux项目自动化构建工具-make/Makefile、linux下第一个小程序–进度条、git以及gitee,本文以及软件管理器yum和编辑器vim和Linux编译器-gcc/g++和Linux调试器-gdb详细的介绍了linux下开发工具的使用。希望给友友们带来帮助!
原文地址:https://blog.csdn.net/m0_57388581/article/details/132438112
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.7code.cn/show_40372.html
如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!