ヾ(๑╹◡╹)ノ" 人总要为过去的懒惰而付出代价ヾ(๑╹◡╹)ノ"
一、Linux项目自动化构建工具-make/Makefile
1.1 背景
- 一个工程中的源文件不计数,其按范例、功能、模块分别放在若干个目录中,makefile定义了一系列的规则来指定,哪些文件需要先编译,哪些文件需要后编译,哪些文件需要重新编译,甚至于进行更复杂的功能操作
- makefile带来的利益就是——“自动化编译”,一旦写好,只需要一个make命令,整个工程完全自动编译,极大的提高了软件开发的服从。
- make是一个命令工具,是一个解释makefile中指令的命令工具,一般来说,大多数的IDE都有这个命令,比如:Delphi的make,Visual C++的nmake,Linux下GNU的make。可见,makefile都成为了一种在工程方面的编译方法。
- make是一条命令,makefile是一个文件,两个搭配使用,完成项目自动化构建。
makefile: 在当前路径下的一个普通文件
1.2 实例代码
在命令行输入make,编译器就会生成可实行文件。
目标:形成可实行文件【就要有依赖关系和依赖方法】
依赖关系
上面的文件 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
第一种
- gcc -o hello main.c hello.c 【由于hello.h在这两个文件中会展开,所以仅仅这两个文件生成可实行程序】
- ./hello 【运行可实行程序】 rm hello【删除】
第二种
- touch makefile
- vim makefile
- 文件内里内容
- make
- make clean
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 项目清理
输入命令:make clean
- 工程是需要被清理的
- 像clean这种,没有被第一个目标文件直接或间接关联,那么它背面所定义的命令将不会被自动实行,不外,我们可以显示要make实行。即命令——“make clean”,以此来清除所有的目标文件,以便重编译。
- 但是一般我们这种clean的目标文件,我们将它设置为伪目标,用 .PHONY 修饰,伪目标的特性是,总是被实行的。【总是被实行的意思是:无论是目标文件是否新旧,仍然会实行依赖关系的依赖方法】
- .PHONY 可以当做“Makefile的关键字,修饰的是伪目标。 PHONY:伪目标
- 当我们make的时间,默认实行的是形成可实行文件,而不是clean,由于默认实行的是第一个依赖关系的依赖方法。
- 不是.PHONY 修饰,实行方法不是总是被实行的。那么Makefile如何辨别是否是最新的?通过对比源文件和可实行文件的Modify时间 ,来决定是否更新可实行文件。
1.修改内容会引起文件属性发生发生厘革。
2.Access访问会发生厘革【但是linux访问累积到一定次数才会发生厘革,由于访问的次数会非常多,经常发生厘革,会影响服从】
二、linux下第一个小程序-进度条
2.1 行缓冲区
sleep(x);休眠函数,休眠x秒钟
- #include <stdio.h>
- 2 #include <unistd.h>
- 3
- 4 int main()
- 5 {
- 6 printf("hello\n");
- 7 sleep(2);
- 8 return 0;
- 9 }
复制代码
但是hello却是后显示的,由于实行结果在缓冲区,并不是先实行第二条代码。
立马把缓冲区内容显示出来—刷新【行刷新,由于有\n,所以够一行,行刷新,所以就显示了出来】
不想有\n但是却想显示出来,可以刷新stdout
代码展示:
- #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 }
复制代码 立马把缓冲区内容显示出来,再就寝2秒。
换行和回车的概念:
换行:新起一行【光标在上一行最后位置往下移一行。】
回车:光标回到当前行的最开始【仅仅回车\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("%d\r", 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, '\0', sizeof(bar));
- 11 const char* lable = "|/-\";
- 12 int i = 0;
- 13 while(i <= 100)
- 14 {
- 15 printf("\033[43;34m%-100s\033[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(“\033[43;34m%-100s\033[0m[%d%%][%c]\r”, bar, i, lable[i%4]);
这里的\033[背景颜色;字体样色 字符串 \033[0m 这是一个固定格式。
注意:test1、clean都要顶格写。
三、git以及gitee
安装git: yum install git
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"
复制代码 (4)git push
就提交到gitee啦~
增补知识:.gitignore 这个文件内里文件后缀是不能提交到gitee的
总结
以上就是今天要讲的内容,本文具体地介绍了Linux项目自动化构建工具-make/Makefile、linux下第一个小程序-进度条、git以及gitee,本文以及软件管理器yum和编辑器vim和Linux编译器-gcc/g++和Linux调试器-gdb具体的介绍了linux下开发工具的使用。盼望给友友们带来帮助!
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。 |