1、Git本地版本库结构

如下图所示:

  1. 工作区(Working Directory

    添加、编辑、修改、删除文件等操作。
  2. 暂存区(Stage

    打算提交,但还没提交的内容。最后可以统一提交到Git仓库中。也可以不提交,撤销回来。
  3. Git仓库(Git Repository

    实实在在的项目存储的每个一历史的版本。

2、Git常用操作方法

Git的专属命令都是以git开始的,然后是索要执行的操作,最后还可以加上一些参数。

以下命令都需在仓库中执行。

(1)状态查看。

命令: git status

命令作用:查看工作区、暂存区状态。

(2)添加文件到暂存区。

命令:git add [file name]

命令作用:

  • 该命令的作用是告诉Git系统,将指定文件的当前快照写入到版本库暂存区。即,将文件交给Git进行版本管理。
  • 提交到暂存区,并且转换文件中的换行符。
  • 被Git追踪的暂存区中的文件可以被提交到本地版本库。

(3)文件从暂存区撤回到工作区。

命令:git rm --cached [file name]

命令作用:把文件从暂存区撤回到工作区。

(4)提交文件。

命令:git commit -m '本次提交的说明'

命令作用:提交操作就通过命令将Git暂存区中的文件快照永久性地写入到本地版本库中。

3、补充:添加多个文件到暂存区

有两种方式:

  • git add命令后添加多个文件,文件之间使用空格分隔。
  • git add命令后使用通配符*指定多个文件。

示例:

  1. # 1.查看工作区、暂存区状态
  2. L@DESKTOP-T2AI2SU MINGW64 /j/git-repository/learngit (master)
  3. $ git status
  4. On branch master
  5. Untracked files:
  6. (use "git add <file>..." to include in what will be committed)
  7. hello.java # 文件名为红色
  8. test.java # 文件名为红色
  9. xyj-sha_hs.py # 文件名为红色
  10. xyj-sun_wk.py # 文件名为红色
  11. xyj-zhu_bj.py # 文件名为红色
  12. nothing added to commit but untracked files present (use "git add" to track)
  13. # 2.添加多个文件到暂存区
  14. L@DESKTOP-T2AI2SU MINGW64 /j/git-repository/learngit (master)
  15. $ git add hello.java test.java
  16. L@DESKTOP-T2AI2SU MINGW64 /j/git-repository/learngit (master)
  17. $ git status
  18. On branch master
  19. Changes to be committed:
  20. (use "git restore --staged <file>..." to unstage)
  21. new file: hello.java # 文件名为绿色
  22. new file: test.java # 文件名为绿色
  23. Untracked files:
  24. (use "git add <file>..." to include in what will be committed)
  25. xyj-sha_hs.py # 文件名为红色
  26. xyj-sun_wk.py # 文件名为红色
  27. xyj-zhu_bj.py # 文件名为红色
  28. # 3.使用通配符添加多个文件到暂存区
  29. L@DESKTOP-T2AI2SU MINGW64 /j/git-repository/learngit (master)
  30. $ git add xyj*.py
  31. L@DESKTOP-T2AI2SU MINGW64 /j/git-repository/learngit (master)
  32. $ git status
  33. On branch master
  34. Changes to be committed:
  35. (use "git restore --staged <file>..." to unstage)
  36. new file: hello.java # 文件名为绿色
  37. new file: test.java # 文件名为绿色
  38. new file: xyj-sha_hs.py # 文件名为绿色
  39. new file: xyj-sun_wk.py # 文件名为绿色
  40. new file: xyj-zhu_bj.py # 文件名为绿色

4、补充:提交操作未写备注

如果你在执行git conmit提交命令的时候,并没有写-m信息,这时会启动文本编辑器,以便输入本次提交的说明。

默认的提交消息包含最后一次运行git status的输出,放在注释行里,如下图:

另外开头还有一空行,供你输入提交说明。你完全可以去掉这些注释行,不过留着也没关系,多少能帮你回想起这次更新的内容有哪些。

如下:

会弹出一个窗口,一个vim编辑器窗口:

说明:

  1. # Please enter the commit message for your changes. Lines starting
  2. # with '#' will be ignored, and an empty message aborts the commit.
  3. #
  4. # On branch master
  5. # Changes to be committed:
  6. # modified: readme.txt
  7. #
  1. Please enter the commit message for your changes. Lines starting

    with '#' will be ignored, and an empty message aborts the commit.

    对于你这次提交中修改的内容要进行说明,

    以'#'开头的行将被忽略,并且在第一行填写说明信息。
  2. Changes to be committed: modified: readme.txt

    readme.txt的修改已被Git追踪到。

进行提交说明的补充:

保存并退出后,提交成功,如下图:

总结:当提交操作的说明内容比较多,或者需要写的比较详细的时候,可以使用这种方式提交。

5、补充:从工作区直接提交到版本库

尽管使用暂存区域的方式,可以准备好要提交的细节,但有时候这么做略显繁琐。

Git提供了一个跳过使用暂存区域的方式,只要在提交的时候,给git commit命令加上-a选项,Git就会自动把所有已经跟踪过的文件,暂存起来一并提交,从而跳过git add步骤。

命令:git commit -a

示例:

(1)先查看当前工作目录中的文件状态。

  1. L@DESKTOP-T2AI2SU MINGW64 /j/git-repository/learngit (master)
  2. $ git status
  3. On branch master
  4. nothing to commit, working tree clean

可以看到非常的干净。

(2)我们创建两个文件。

一个文件是新增文件test.txt,此前没有被Git追踪过。

两个文件是readme.txt,已被Git追踪,我们将该文件变成已修改状态。

  1. # 1.新建test.txt
  2. L@DESKTOP-T2AI2SU MINGW64 /j/git-repository/learngit (master)
  3. $ echo "hello test" > test.txt
  4. # 2.修改readme.txt文件
  5. L@DESKTOP-T2AI2SU MINGW64 /j/git-repository/learngit (master)
  6. $ echo "hello git v666" >> readme.txt
  7. # 3.查看工作目录中的文件状态
  8. L@DESKTOP-T2AI2SU MINGW64 /j/git-repository/learngit (master)
  9. $ git status
  10. On branch master
  11. Changes not staged for commit:
  12. (use "git add <file>..." to update what will be committed)
  13. (use "git restore <file>..." to discard changes in working directory)
  14. modified: readme.txt # 已修改状态,未在暂存区
  15. Untracked files:
  16. (use "git add <file>..." to include in what will be committed)
  17. test.txt # 未追踪状态
  18. no changes added to commit (use "git add" and/or "git commit -a")

(3)提交到Git版本库中。

我们直接使用git commit -a -m命令直接执行提交操作,看看会发生什么情况。

  1. # 提交
  2. L@DESKTOP-T2AI2SU MINGW64 /j/git-repository/learngit (master)
  3. $ git commit -a -m 'test -a'
  4. [master 1b0de31] test -a
  5. 1 file changed, 1 insertion(+)
  6. # 查看工作目录文件状态
  7. L@DESKTOP-T2AI2SU MINGW64 /j/git-repository/learngit (master)
  8. $ git status
  9. On branch master
  10. Untracked files:
  11. (use "git add <file>..." to include in what will be committed)
  12. test.txt # 未追踪状态
  13. nothing added to commit but untracked files present (use "git add" to track)

我们可以看到,未被追踪状态的文件,不能直接从工作区直接提交到版本库,使用-a选择也不可以。

『现学现忘』Git基础 — 14、Git基础操作的总结与补充的更多相关文章

  1. 『现学现忘』Git基础 — 13、Git的基础操作

    目录 1.Git最基础的使用方式 (1)初始化本地版本库 (2)查看文件的状态 (3)把文件添加到暂存区 (4)把暂存区的内容提交到本地版本库 2.总结本文用到的Git命令 1.Git最基础的使用方式 ...

  2. 『现学现忘』Git基础 — 2、Git和SVN的区别

    1.Git和SVN的区别 (1)SVN(集中式版本管理系统) 集中式的版本控制系统都有一个单一的集中管理的服务器,保存所有文件的修订版本,而协同工作的人们都通过客户端连到这台服务器,取出最新的文件或者 ...

  3. 『现学现忘』Git基础 — 3、Git介绍

    目录 1.Git的历史 2.Git的特点 3.Git在项目协作开发中所解决的问题 1.Git的历史 Git是目前世界上最先进的分布式版本控制系统,开源.免费. Git 是 Linus (林纳斯)为了帮 ...

  4. 『现学现忘』Git基础 — 4、Git下载与安装

    目录 1.Git下载 2.Git在Windows下的详细安装 3.验证Git是否安装成功 1.Git下载 进入官方地址下载Git客户端:https://git-scm.com/download/win ...

  5. 『现学现忘』Git基础 — 7、设置Git Bash终端默认路径

    目录 1.Git Bash默认路径 2.如何查看Git Bash终端默认路径 3.如何修改Git Bash终端的默认路径 4.拓展:指定目录进入Git Bash终端 5.注意事项 如果您不熟悉Git命 ...

  6. 『现学现忘』Git基础 — 12、Git用户签名(补充)

    目录 1.修改用户签名 2.取消用户签名 3.用户签名的优先级 4.总结本文用到的Git命令 1.修改用户签名 其实很简单,就是重新执行git config命令,换个用户名和邮箱地址就可以了,新配置的 ...

  7. 『现学现忘』Git基础 — 19、在Git中进行忽略文件操作

    目录 1.忽略文件说明 2.忽略文件的原则 3..gitignore忽略规则 4.忽略文件的三种方式 (1)忽略单个仓库中的文件(远程共用) (2)忽略单个仓库中的文件(本地使用) (3)全局忽略 1 ...

  8. 『现学现忘』Git基础 — 23、Git中的撤销操作

    目录 1.撤销操作说明 2.撤销工作区中文件的修改 3.撤销暂存区中文件的修改 4.总结 1.撤销操作说明 我们在使用Git版本管理时,往往需要撤销某些操作.比如说我们想将某个修改后的文件撤销到上一个 ...

  9. 『现学现忘』Git基础 — 24、Git中查看历史版本记录

    目录 1.查看详细的历史版本记录 2.简化显示历史版本记录 3.历史版本记录常用操作 (1)指定查看最近几次提交的内容 (2)以简单图形的方式查看分支版本历史 (3)翻页与退出 4.查看分支相关的版本 ...

随机推荐

  1. bzoj4596/luoguP4336 [SHOI2016]黑暗前的幻想乡(矩阵树定理,容斥)

    bzoj4596/luoguP4336 [SHOI2016]黑暗前的幻想乡(矩阵树定理,容斥) bzoj Luogu 题解时间 看一看数据范围,求生成树个数毫无疑问直接上矩阵树定理. 但是要求每条边都 ...

  2. C++中的RAII介绍

    摘要 RAII技术被认为是C++中管理资源的最佳方法,进一步引申,使用RAII技术也可以实现安全.简洁的状态管理,编写出优雅的异常安全的代码. 资源管理 RAII是C++的发明者Bjarne Stro ...

  3. Java Arrays.asList(0,1,2,3,4,5,6,7,8,9).parallelStream().forEach 进行循环获取HttpServletRequest的为Null的解决方案

    Arrays.asList(0,1,2,3,4,5,6,7,8,9).parallelStream().forEach() parallelStream是并行执行流的每个元素,也就是多线程执行,这样就 ...

  4. spring源码-扩展点

    /** * @Author quan * @Date 2020/11/13 * 扩展原理 * BeanPostProcessor bean后置处理器,bean创建对象初始化前后进行拦截工作 * * * ...

  5. Netty学习摘记 —— 再谈ChannelHandler和ChannelPipeline

    本文参考 本篇文章是对<Netty In Action>一书第六章"ChannelHandler和ChannelPipeline",主要内容为ChannelHandle ...

  6. 翻译:HTML5与HTML4的区别

    本文选译自:W3C Working Group Note: HTML5 Differences from HTML4. 解释一下W3C Working Group Note,作为"工作组笔记 ...

  7. H5优化:canonical标签该如何正确使用

    对一组内容完全相同或高度相似的网页,通过使用Canonical标签可以告诉搜索引擎哪个页面为规范的网页,能够规范网址并避免搜索结果中出现多个内容相同或相似的页面,帮助解决重复内容的收录问题,避免网站相 ...

  8. 如何保证同事的代码不会腐烂?一文带你了解 阿里巴巴 COLA 架构

    一起养成写作习惯!这是我参与「掘金日新计划 · 4 月更文挑战」的第1天,点击查看活动详情. 本文开始前,问大家一个问题,你觉得一份业务代码,尤其是互联网业务代码,都有哪些特点? 我能想到的有这几点: ...

  9. 子线程中如何修改ui界面

    1.Android进程 一个应用程序被启动时,系统默认创建执行一个叫做"main"的线程.这个线程也是你的应用与界面工具包(android.widget和android.view包 ...

  10. source /etc/profile 不起作用?

    给Linux配置了环境变量,source /etc/profile 完成之后只在当前用户下起作用,切换用户后设置的环境变量竟然没有生效!重启后虽然生效了,但是想知道怎么回事. 找到了如下解答: 假设你 ...