Linux gcc day7

动态链接和静态链接

形成的可执行的程序小:节省资源--内存,磁盘

 

 

无法c静态库链接的方法

原因是我们没有安装静态c库(.a)

所以要安装

sudo yum install -y glibc-static

gcc static静态编译选项提示错误:/usr/lib/ld:cannot find -lc - 小禾先生 - 博客园 (cnblogs.com)

我们的指令都是链接动态库的所以不可以乱删系统的c  库的东西

 c++静态标准库

 sudo yum install -y libstdc++-static

 

Linux项目自动化构建工具-make/Makefile

make是一个命令,makefile是一个文件

 touch M/makefile   //首字母可以大写也可以小写

vim M/makefile

makefile注意的事项

:是依赖关系 

tab开头的是依赖方法

那如何用makefile清理?

编辑makefile文件

make是怎样执行的?

伪目标PHONY(下面有详细)

那系统是如何知道编译的文件为最新的呢?

是根据时间来判断

stat命令查看文件的时间

介绍 stat下的(access modify change(属性、权限))

为什么修改了文件的内容,change要修改呢?

因为当内容修改了,文件的大小就会修改所以change的是时间也会改变 

回到话题

那系统是如何知道编译的文件为最新的呢?

是根据修改时间modify,因为先有源文件再有可执行目标文件,所以可执行文件的modify总是比源文件的modify要新,如果源文件被修改了那modify就会被修改,那系统就会用可执行文件modify和源文件modify对比就可以知道是否要更新

所以出现了伪目标.phony    (停止以modify时间来判断or不以时间来判断)

makefile的推导规则:

不建议这样写,了解就好

 

Linux下的第一个小程序

了解下这个函数

fflush()函数-CSDN博客

倒计时:

/n是具有行刷新,fflush也具备行刷新(缓冲区刷新)

多文件形式编写进度条

 

 编写完成保存退出

对makefile的编写

执行成功但是它会遮住命令行所以我们在函数下加printf("\n") 

现在进行优化添加进度:如10%,50%

效果:

添加旋转效果:

增加进度条的形状选择

git命令行

git是什么?

 版本控制器,类似于云仓库

自建网站----->我的版本控制器(git)可以不用客户端,直接在浏览器上可以进行操作 

这个浏览器叫github(国外),因为国内原因访问不了外网(访问很慢)所以国人自己建立

gitee,git其实就是工具(去中心的分布化的版本控制器)

git发展史

git操作

进入gitee网站

回到Linux centos7 我的是xshell远程服务器

在选择自己合适的目录下

git clone 【自己复制的仓库链接】      //将远端的仓库拉取下来

因为.gitignore是.开头的隐藏文件所以要

ls -al 或者ll -a

vim .gitignore    //打开

这文件上有的文件后缀名对应的文件是不会被上传到gitee上

为什么?因为gitee只接收  .c  .h  .cpp等源文件

将本地的仓库上传到远端的gitee上

实验:

yum install -y git           //先安装git工具

 git add .     / /将新创建的文件添加到本地仓库.git   (.git的临时区)

只要知道刚刚的命令将process文件经过二进制解码的方式添加到  .git 本地仓库就行

先不用管添加到哪里 

(添加到本地仓库的临时区)

 git commit -m ‘xxxxxx’   //xxx为日志不要乱写

将临时区的文件添加到本地仓库

push git    //将本地的仓库推送到远端

 

提交成功 

git log    //查看日志

做一个实验

(准备环境)

第二步

现在我们已经在仓库里面建立的许多文件,如何对比呢?

git status     //查看状态 

现在有新增的也要修改的

怎么办呢?

git add .    //将当前的目录下去找所有不存在的文件

打开gitee

我们在process目录下做的修改

若我们想要整体修改就要在最外面的目录下进行

git mv 【文件名】 【new文件名】

回到gitee,已经修改了

也就是本地和远端是同步的

刚刚的sln文件也没有传上来

很重要

注意:只可以口述

如果有一天一个人在gitee下直接修改了文件内容

另一个人在Linux本地仓库下增加了一个文件

想要同步远端仓库

hint :冲突

会有提示因为不同步,所以需要

git pull        //将远端的仓库拉到本地

此时输入账号密码

会出现很多垃圾文件直接无视  :wq退出就行

搞完后再git push

现在远端和本地发生了同步

删除

git rm 【文件名】

git log

相关推荐

  1. CTF <span style='color:red;'>7</span>

    CTF 7

    2024-04-25 00:50:01      52 阅读
  2. ARMday<span style='color:red;'>7</span>

    ARMday7

    2024-04-25 00:50:01      56 阅读
  3. DevOps(7)

    2024-04-25 00:50:01       53 阅读
  4. HCIP-<span style='color:red;'>7</span>

    HCIP-7

    2024-04-25 00:50:01      48 阅读
  5. ARMday<span style='color:red;'>7</span>

    ARMday7

    2024-04-25 00:50:01      43 阅读
  6. <span style='color:red;'>7</span>.string

    7.string

    2024-04-25 00:50:01      33 阅读
  7. MySQL(7

    2024-04-25 00:50:01       32 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-25 00:50:01       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-25 00:50:01       100 阅读
  3. 在Django里面运行非项目文件

    2024-04-25 00:50:01       82 阅读
  4. Python语言-面向对象

    2024-04-25 00:50:01       91 阅读

热门阅读

  1. ElasticSearch(3)

    2024-04-25 00:50:01       35 阅读
  2. ceph存储系统

    2024-04-25 00:50:01       28 阅读
  3. Android判断应用是否在前台运行

    2024-04-25 00:50:01       33 阅读
  4. 2024/4/24总结

    2024-04-25 00:50:01       32 阅读
  5. 手撕代码: C++实现数据的序列化和反序列化

    2024-04-25 00:50:01       29 阅读