Git工作/面试必知必会操作-命令行篇(二)

2 Git 发展史

Linux 内核开源项目有着为数众广的参与者。绝大多数的 Linux 内核维护工作都花在了提交补丁和保存归档的繁琐事务上(1991-2002年间)。到 2002 年,整个项目组开始启用分布式版本控制系统 BitKeeper 来管理和维护代码。


到了 2005 年,开发 BitKeeper 的商业公司同 Linux 内核开源社区的合作关系结束,他们收回了免费使用 BitKeeper 的权力。这就迫使 Linux 开源社区(特别是 Linux 的缔造者 Linus Torvalds )不得不吸取教训,只有开发一套属于自己的版本控制系统才不至于重蹈覆辙。他们对新的系统制订了若干目标:


速度

简单的设计

对非线性开发模式的强力支持(允许上千个并行开发的分支)

完全分布式

有能力高效管理类似 Linux 内核一样的超大规模项目(速度和数据量)

自诞生于 2005 年以来,Git 日臻成熟完善,在高度易用的同时,仍然保留着初期设定的目标。它的速度飞快,极其适合管理大项目,它还有着令人难以置信的非线性分支管理系统(见第三章),可以应付各种复杂的项目开发需求。


2 Git 命令

2.1 Git配置

$ git config --global user.name "Your Name"
$ git config --global user.email "email@example.com"

git config命令的--global参数,表明这台机器上的所有Git仓库都会使用这个配置,也可以对某个仓库指定不同的用户名和邮箱地址。

2.2 分区管理

Git工作/面试必知必会操作-命令行篇(二)

工作区

在电脑里能看到的目录

版本库

在工作区有一个隐藏目录.git,是Git的版本库。

Git的版本库中存了很多东西,其中

  • 最重要的就是称为stage(或者称为index)的暂存区
    • git add就是把文件添加到暂存区
  • 还有Git自动创建的master
  • 指向master的指针HEAD

git commit 把暂存区的所有内容提交到当前分支

版本库

初始化一个Git仓库

$ git init

添加文件到Git仓库

包括两步:

$ git add <file>
$ git commit -m "description"

git add可以反复多次使用,添加多个文件,git commit可以一次提交很多文件,-m后面输入的是本次提交的说明,可以输入任意内容。

查看工作区状态

$ git status

查看修改内容

$ git diff
$ git diff --cached
$ git diff HEAD -- <file>
  • git diff 可以查看工作区(work dict)和暂存区(stage)的区别
  • git diff --cached 可以查看暂存区(stage)和分支(master)的区别
  • git diff HEAD -- <file> 可以查看工作区和版本库里面最新版本的区别


查看提交日志

$ git log

简化日志输出信息

$ git log --pretty=oneline

查看命令历史

$ git reflog

版本回退

$ git reset --hard HEAD^

以上命令是返回上一个版本.

在Git中:

  • HEAD 当前版本
  • HEAD^ 上一版本
  • HEAD^^ 上上个版本
  • HEAD~n n 个版本之前

回退指定版本号

$ git reset --hard commit_id

commit_id是版本号,是一个用SHA1计算出的序列

撤销修改

丢弃工作区的修改

$ git checkout -- <file>

该命令是指将文件在工作区的修改全部撤销,这里有两种情况:

  1. 一种是file自修改后还没有被放到暂存区,现在,撤销修改就回到和版本库一模一样的状态;
  2. 一种是file已经添加到暂存区后,又作了修改,现在,撤销修改就回到添加到暂存区后的状态。


总之,就是让这个文件回到最近一次git commit或git add时的状态。

丢弃暂存区的修改

分两步:

第一步,把暂存区的修改撤销掉(unstage),重新放回工作区:

$ git reset HEAD <file>

第二步,撤销工作区的修改

$ git checkout -- <file>

小结:

当你改乱了工作区某个文件的内容,想直接丢弃工作区的修改时,用命令git checkout -- <file>


当你不但改乱了工作区某个文件的内容,还添加到了暂存区时,想丢弃修改,分两步,第一步用命令git reset HEAD <file>,就回到了第一步,第二步按第一步操作。


已经提交了不合适的修改到版本库时,想要撤销本次提交,进行版本回退,前提是没有推送到远程库。


删除文件

$ git rm <file>

git rm <file>相当于执行

$ rm <file>
$ git add <file>

进一步的解释

Q:比如执行了rm text.txt 误删了怎么恢复?

A:执行git checkout -- text.txt 把版本库的东西重新写回工作区就行了

Q:如果执行了git rm text.txt我们会发现工作区的text.txt也删除了,怎么恢复?

A:先撤销暂存区修改,重新放回工作区,然后再从版本库写回到工作区

$ git reset head text.txt
$ git checkout -- text.txt

Q:如果真的想从版本库里面删除文件怎么做?

A:执行git commit -m "delete text.txt",提交后最新的版本库将不包含这个文件

git rm 与 git rm --cached

当我们需要删除暂存区或分支上的文件, 同时工作区也不需要这个文件了, 可以使用

git rm file_path

当我们需要删除暂存区或分支上的文件, 但本地又需要使用, 只是不希望这个文件被版本控制, 可以使用

git rm --cached file_path


上一篇:python版本升级


下一篇:git 入门第一节 创建版本库 及 相关命令使用