1.git介绍
1.版本控制器
为了能够更⽅便我们管理这些不同版本的⽂件,便有了版本控制器。所谓的版本控制器,就是能让你了解到⼀个⽂件的历史,以及它的发展过程的系统。通俗的讲就是⼀个可以记录⼯程的每⼀次改动和版本迭代的⼀个管理系统,同时也⽅便多⼈协同作业。⽬前最主流的版本控制器就是 Git
。Git可以控制电脑上所有格式的⽂件,例如doc、excel、dwg、dgn、rvt等等 。对于我们开发⼈员来说,Git最重要的就是可以帮助我们管理软件开发项⽬中的源代码⽂件!
2.git简史
同⽣活中的许多伟⼤事物⼀样,Git诞⽣于⼀个极富纷争⼤举创新的年代。
Linux内核开源项⽬有着为数众多的参与者。绝⼤多数的Linux内核维护⼯作都花在了提交补丁和保存归档的繁琐事务上(1991−2002年间)。到2002年,整个项⽬组开始启⽤⼀个专有的分布式版本控制系统BitKeeper来管理和维护代码。到了2005年,开发BitKeeper的商业公司同Linux内核开源社区的合作关系结束,他们收回了Linux内核社区免费使⽤BitKeeper的权⼒。这就迫使Linux开源社区(特别是Linux的缔造者LinusTorvalds)基于使⽤BitKeeper时的经验教训,开发出⾃⼰的版本系统。
⾃诞⽣于2005年以来,Git⽇臻成熟完善,在⾼度易⽤的同时,仍然保留着初期设定的⽬标。它的速度⻜快,极其适合管理⼤项⽬,有着令⼈难以置信的⾮线性分⽀管理系统。
2.linux下拉取gitee远端仓库(git三板斧)
1.新建一个仓库
data:image/s3,"s3://crabby-images/0a873/0a873c628cb4c6071631ba1017443d6f2844d07a" alt=""
仓库明细如下:
可以看到有两个初始的.md文件(注意)
2.获取gitee仓库地址
这个就是我们需要的仓库地址
3.拉取gitee远端仓库
- 使用
git clone +仓库网址
就能把仓库内容拉取出来 - 可见两个md文件与仓库中的一致
3.在拉下来的仓库里新增内容并提交到远程仓库
data:image/s3,"s3://crabby-images/b4f27/b4f274f85739dcc093b190a333d6e4b67291f151" alt=""
这里使用了其他大佬的图。
data:image/s3,"s3://crabby-images/ff39f/ff39f36c29de640b00846a34c4b00fc750cfa6da" alt=""
这里我们在克隆的目录下新建一个code.c我们可以使用vim在文件里写入一些代码。
1.git add code.c
data:image/s3,"s3://crabby-images/6e8fb/6e8fb1167b5e560393c2530861fb12d1f0a7a358" alt=""
请问这里code.c有被直接提交到本地仓库吗?
NO!
当前code.c只是被存在了暂存区 (方便收回,避免提交错误的代码到远程仓库里)
data:image/s3,"s3://crabby-images/7eab5/7eab5e3f504fc46d75176110ac27c56710f5c001" alt=""
2.git status(查看当前情况)
data:image/s3,"s3://crabby-images/9c72b/9c72b9d53c2a2b930136312e83c02b35a179b006" alt=""
那么,我们有办法传到本地仓库吗?
有的,兄弟有的:
3.git commit -m "新增一个文件"(在git add的基础上)
data:image/s3,"s3://crabby-images/3d13c/3d13ce232117f667de2dca1aa122f1d06172ef85" alt=""
这个时候会报错,因为我们是第一次使用git,需要给 邮箱和名字
data:image/s3,"s3://crabby-images/78dc5/78dc5dae16e62b2a71969a4fe3d11101541f80e8" alt=""
这里大佬们可以填自己的
data:image/s3,"s3://crabby-images/224de/224de1c15cf1f83721d0fa8da4d9b7921bdc6360" alt=""
再次使用就成功啦。
4.git log (相当于日志)
data:image/s3,"s3://crabby-images/e9138/e9138f6d6cd0e84d7e7e620d9ad6a187a6099a3f" alt=""
可以用来查看日志,检查错误
5.git push
data:image/s3,"s3://crabby-images/63914/6391443a397460df6ac34f1a64e94a94c4d5a644" alt=""
第一次使用需要将红框中的内容任选其一输入到终端
然后再输入git push
data:image/s3,"s3://crabby-images/5ea09/5ea09a42dc9f964c5a4faf4fc3860983e62f5062" alt=""
输入密码和账户即可
data:image/s3,"s3://crabby-images/c5894/c589426fb9f2794e117cf6e0131686a90607754f" alt=""
远程仓库也完成了传输啦。
4.git指令扩充
- 删除仓库中的文件 ------
git rm 文件名
- 查看本地和远端之间同步的状态 ------
git status
- 删除本地仓库 ------
rm .git
data:image/s3,"s3://crabby-images/eb351/eb35177a5ba47bf4410f929900b9dfaf08125317" alt=""
code.c文件已经被删除
data:image/s3,"s3://crabby-images/5658b/5658b76c33160061e93fdb46c0db0df5c97c1518" alt=""
使用git status也显示code.c被删除
接下来我们把下载的本地仓库也删除:
data:image/s3,"s3://crabby-images/29fd7/29fd7741a4ed04dff28994232c7e290bffb5e7f9" alt=""
这里再次使用git status 发现没法查看,因为.git已经被删除。
data:image/s3,"s3://crabby-images/ffced/ffced01ff079b15add773a78bb115ff273d01010" alt=""
- 我们可以看到有个.gitignore文件,这个文件储存着
所有会被忽视的文件后缀
,即如果在linux/windows下传了上述后缀的文件,仓库里是不会显示这些文件的