首页 > 其他 > 详细

Git学习笔记(二)

时间:2019-03-21 16:56:36      阅读:122      评论:0      收藏:0      [点我收藏+]

修改添加的文件

完成添加和提交readme.txt文件,修改操作如下:
$ vi readme.txt

# 修改内容
Git is a distributed version control system.
Git is free software.

运行git status查看结果
技术分享图片
上述提示信息为readme.txt文件已经被修改,但是还未提交更改
运行git diff查看被修改的内容
技术分享图片
确定修改结果后,按照相同步骤提交

$ git status
# 运行git status再次查看当前仓库的状态
git status

技术分享图片
将要提交被修改的readme.txt文件

# 提交
git commit -m "add distributed"

技术分享图片
修改结束

版本回退

再次修改readme.txt文件并提交修改

  • 修改内容如下
Git is a distributed version control system.
Git is free software distributed under the GPL.

commit的作用就是将文件修改到一定程度以后保存修改的文件,并且不会改变以前的版本,一旦文件改乱或者误删了某个文件,可以从最近的commit恢复,然后继续修改

  • git log命令查看历史记录
    git log
    技术分享图片
    git log命令显示从最近到最远的提交日志
  • git log --pretty=oneline使提示信息的输出更为简洁明了
    技术分享图片
  • 开始回退到指定版本
    Git中,用HEAD表示当前版本(最新提交的文件),上一个版本HEAD^,第50个版本HEAD~50
  • git reset回溯到指定版本
$ git reset --hard HEAD^^
HEAD is now at wrote a readme file

cat readme.txt查看当前版本内容

技术分享图片

  • 指定回到未来的某个版本
    git reset --hard 版本号
    技术分享图片
  • git reflog查看所操作的每一次命令
    技术分享图片
  • HEAD指向的版本就是当前版本,因此,Git允许我们在版本的历史之间穿梭,使用git reset --hard commit_id
  • git log可以查看提交历史,以确定要回退到哪个版本
  • 要重返新的版本(未来),用git reflog查看命令历史,以便要确定回到(未来)哪个版本

    工作区和暂存区

  • Mygit就是工作区
    -工作区隐藏的目录.git叫做Git的版本库,版本库里最重要的部分是stage(或者index),叫做暂存区,还包括第一个分支master,以及指向master的一个指针HEAD
    技术分享图片
    需要提交的文件修改一律放到暂存区,然后,可以一次性提交暂存区的所有修改
    再次修改readme.txt文档:
Git is a distributed version control system.
Git is free software distributed under the GPL.
Git has a mutable index called stage.

然后新增加License.txt文件,用git status查看当前状态
技术分享图片
readme.txt被修改了;License.txt从未被修改,状态为Untracked
将两个文件夹都add,查看状态
技术分享图片
此刻暂存区如下图所示:
技术分享图片
执行git commit一次性将暂存区的文件提交到分支master

技术分享图片
提交结束,工作区clear
技术分享图片

管理进行的修改

再次修改readme.txt文件

Git is a distributed version control system.
Git is free software distributed under the GPL.
Git has a mutable index called stage.
Git tracks changes.

技术分享图片
继续修改readme.txt,然后提交
技术分享图片
查看状态
技术分享图片
此时,第二次修改未被提交,原因是第二次提交并未执行git add,也就是说,第二次修改的文件依旧存储在工作区,并未add到暂存区(stage)
git diff HEAD -- readme.txt查看工作区版本和版本库中的最新版本的区别:
技术分享图片
继续执行git add,把第二次修改提交,随后git commit -m
技术分享图片

撤销修改

  • 文件修改出错
    技术分享图片
  1. 只是在工作区进行修改,并未执行git addgit commit -m " "命令
    技术分享图片
  • 可以执行git checkout -- readme.txt丢弃工作区的修改
    技术分享图片
  1. 工作区修改出错,并且已经git add到暂存区
    技术分享图片
    但是并未执行git commit
  • 用命令git reset HEAD readme.txt可以把暂存区的修改撤销掉(unstage),重新放回到工作区:
    技术分享图片
    技术分享图片
  • 丢弃工作区修改
    技术分享图片

    删除文件

  • 添加新文件
    技术分享图片
  • 执行rm命令直接在文件管理器中删除test.txt文件
    rm test.txt
    技术分享图片

    此时执行的操作有两种:

  • 确定要删除版本库中的文件,执行命令git rm,然后git commit
    技术分享图片
    此时版本库中的文件已被删除
  • 文件误删(版本库中存有),将误删的文件恢复到最新版本,执行git checkout -- test.txt
    技术分享图片

Git学习笔记(二)

原文:https://www.cnblogs.com/DyerLee/p/10572622.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!