【linux】2 make/Makefile和gitee

打印 上一主题 下一主题

主题 887|帖子 887|积分 2661


ヾ(๑╹◡╹)ノ" 人总要为过去的懒惰而付出代价ヾ(๑╹◡╹)ノ"

一、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秒钟
  1. #include <stdio.h>
  2.   2 #include <unistd.h>
  3.   3
  4.   4 int main()
  5.   5 {
  6.   6   printf("hello\n");                                                                                                                                
  7.   7   sleep(2);
  8.   8   return 0;
  9.   9 }
复制代码

但是hello却是后显示的,由于实行结果在缓冲区,并不是先实行第二条代码。
立马把缓冲区内容显示出来—刷新【行刷新,由于有\n,所以够一行,行刷新,所以就显示了出来】
   不想有\n但是却想显示出来,可以刷新stdout
代码展示:
  1. #include <stdio.h>
  2.   2 #include <unistd.h>
  3.   3
  4.   4 int main()
  5.   5 {
  6.   6   printf("hello");                                                                                                                                 
  7.   7   fflush(stdout);
  8.   8   sleep(2);
  9.   9   return 0;
  10. 10 }
复制代码
  立马把缓冲区内容显示出来,再就寝2秒。
  换行和回车的概念:
换行:新起一行【光标在上一行最后位置往下移一行。】
回车:光标回到当前行的最开始【仅仅回车\r】
换行+回车:新起一行+光标回到当前行的最开始
2.2 进度条

倒计时程序:
  1.   1 #include <stdio.h>                                                                                                                                 
  2.   3 #include <unistd.h>
  3.   4
  4.   5 int main()
  5.   6 {
  6.   7   int n = 9;
  7.   8   while (n)
  8.   9   {
  9. 10     printf("%d\r", n--);
  10. 11     fflush(stdout);
  11. 12     sleep(1);
  12. 13   }
  13. 14   return 0;
  14. 15 }
复制代码
进度条代码:
代码展示:
  1. 1 #include <stdio.h>
  2.   2 #include <string.h>
  3.   3 #include <unistd.h>//usleep的头文件
  4.   4 #define Val 101
  5.   5 #define Style '*'
  6.   6
  7.   7 int main()
  8.   8 {
  9.   9   char bar[Val];
  10. 10   memset(bar, '\0', sizeof(bar));
  11. 11   const char* lable = "|/-\";
  12. 12   int i = 0;
  13. 13   while(i <= 100)
  14. 14   {                                                                                                                                                
  15. 15     printf("\033[43;34m%-100s\033[0m[%d%%][%c]\r", bar, i, lable[i%4]);
  16. 16     fflush(stdout);
  17. 17     usleep(200000);  
  18. 18     bar[i++] = Style;
  19. 19   }            
  20. 20   printf("\n");
  21. 21   return 0;
  22. 22 }
  23. ~
复制代码



  • 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 ‘日志’
此时会出现错误:【由于第一次需要配置用户名和邮箱】

提交以下代码即可解决:
  1. git config --global user.email "you@example.com"
  2. 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企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

勿忘初心做自己

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表