Git

Posted ltef

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Git相关的知识,希望对你有一定的参考价值。

Git是分布式版本控制系统。如果你和同事同时修改了A文件,那么只需要把A文件的修改推送给对方就可以了。

Svn,Cvs是集中式版本控制系统。需要联网才能工作。从中央服务器下载最新代码,并把修改上传到中央服务器。

和集中式版本控制系统相比,Git分布式版本系统的安全性要高得多,因为每个人电脑里都有完整的版本库,某一个人的电脑坏了可以从其他人那里复制。而集中式版本库的中央服务器挂了,所有人都无法工作。

版本库(repository):版本库中的所有文件都可以被Git管理起来,每个文件的修改、删除 Git都能跟踪,以便任何时刻都可以追踪历史,或者在将来某个时刻“还原”。

创建版本库:

1. 在要创建git版本库的文件夹上执行命令: git init

命令执行完成后,会看到一个.git目录,默认是隐藏的。

把文件添加到版本库:

文件建议使用编辑器,如NotePad++书写。方便修改编码方式 --UTF-8

添加文件到仓库命令:
    git add test.txt

文件提交到仓库命令:
    git commit -m "add a txt"   -- 会提交git跟踪到的所有修改文件

退回版本库:

查看仓库当前的状态状态命令:
    # 这个命令可以告诉我们有哪些文件被修改了,哪些文件被删除了等等
    git status

查看具体修改内容:
    git diff test.txt

查看提交信息:
    git log

退回版本:
    git reset -hard HEAD^  -- ^代表退回上一个版本
    git reset -hard ~100   -- ~100往上一百个版本

每次commit都会自动生成一个id,也可以使用id退回版本
    git reset -hard 1094a

Git版本退回非常快,因为Git在内部有一个指向当前版本的指针,当你退回版本的时候,Git仅仅是把HEAD指针指向了其他版本。

注:当退回版本以后,git log只能查看可以回退的版本,不能查看向前的版本,如果向要查看,要使用 git relog查看所有的提交命令

Git工作区、暂存区:

工作区:就是你在电脑里能看到的目录

版本库:隐藏目录.git

git版本库中存贮了很多信息,其中最重要的就是stage的暂存区,还有Git为我们建立的第一个分支master,以及指向master的HEAD

git add、git commit命令含义:

git add 实际就是把文件修改添加到暂存区;
git commit 实际就是把暂存区的所有内容提交到当前分支。

Git修改文件:

第一次修改 -> git add -> 第二次修改 -> git add -> git commit

Git撤销修改:

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

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

场景3:已经提交了不合适的修改到版本库时,想要撤销本次提交,参考版本回退一节,不过前提是没有推送到远程库。

Git删除文件:

删除文件后运行命令
git rm <file>
git commit

若删除文件后发现删错了
git checkout -- <file>  把误删的文件修改到最新版本

Git分支:

创建分支,并切换
git checkout -b dev

git checkout -b dev 相当于:
    git branch dev  创建
    git checkout dev  切换

查看当前分支
git branch

创建之后我们就可以在dev分支上正常提交

dev分支工作完成时,我们就可以切换回master分支,进行合并

git checkout master
git merge dev

合并完成后,我们就可以删除dev分支了

git branch -d dev

提交冲突

当dev分支提交的修改和master分支提交的修改有冲突时,需要我们手动合并修改,再次提交。

查看分支合并图
git log --graph --pretty=oneline --abbrev-commit

分支管理

分支合并后、删除dev分支会丢失分支信息。使用 --no-ff保存分支信息。

git merge --no-ff -m "merge with no-ff" dev

Bug分支

当工作中出现bug需要马上解决,但是手动新的代码还不能提交,可以使用stash功能。

当分支中stash一下,假设当前分支为dev
git stash

切换到需要修改bug的分区
git checkout master

创建修改bug分支
git checkout -b issue-101

提交
git add readme.txt 
git commit -m "fix bug 101"

合并
git checkout master
git merge --no-ff -m "merged bug fix 101"

切换到原分支工作区
git checkout dev

查看当前stash
git stash list

把缓存的dev分支上的修改找回
git stash apply

删除stash
git stash drop

或者直接使用pop恢复并删除stash
git stash pop

Feature分支

分支上的修改没有合并时,若想删除改分支,执行以下命令

git branch -D <name>

多人协作

当你从远程仓库克隆时,实际上Git自动把本地的master分支和远程的master分支对应起来了,并且,远程仓库的默认名称是origin。

要查看远程库的信息,用git remote:

git remote

或者,用git remote -v显示更详细的信息:

git remote -v

推送分支

推送分支,就是把该分支上的所有本地提交推送到远程库。推送时,要指定本地分支,这样,Git就会把该分支推送到远程库对应的远程分支上:

git push origin master

推送到其他分支
git push origin dev

抓取分支

克隆git项目
git clone [email protected]:michaelliao/learngit.git

当你的小伙伴从远程库clone时,默认情况下,你的小伙伴只能看到本地的master分支。不信可以用git branch命令看看

$ git branch
* master

现在,你的小伙伴要在dev分支上开发,就必须创建远程origin的dev分支到本地,于是他用这个命令创建本地dev分支:

$ git checkout -b dev origin/dev

现在,他就可以在dev上继续修改,然后,时不时地把dev分支push到远程:

$ git add env.txt

$ git commit -m "add env"
[dev 7a5e5dd] add env
 1 file changed, 1 insertion(+)
 create mode 100644 env.txt

$ git push origin dev
Counting objects: 3, done.
Delta compression using up to 4 threads.
Compressing objects: 100% (2/2), done.
Writing objects: 100% (3/3), 308 bytes | 308.00 KiB/s, done.
Total 3 (delta 0), reused 0 (delta 0)
To github.com:michaelliao/learngit.git
   f52c633..7a5e5dd  dev -> dev

你的小伙伴已经向origin/dev分支推送了他的提交,而碰巧你也对同样的文件作了修改,并试图推送:

$ cat env.txt
env

$ git add env.txt

$ git commit -m "add new env"
[dev 7bd91f1] add new env
 1 file changed, 1 insertion(+)
 create mode 100644 env.txt

$ git push origin dev
To github.com:michaelliao/learngit.git
 ! [rejected]        dev -> dev (non-fast-forward)
error: failed to push some refs to ‘[email protected]:michaelliao/learngit.git‘
hint: Updates were rejected because the tip of your current branch is behind
hint: its remote counterpart. Integrate the remote changes (e.g.
hint: ‘git pull ...‘) before pushing again.
hint: See the ‘Note about fast-forwards‘ in ‘git push --help‘ for details.

推送失败,因为你的小伙伴的最新提交和你试图推送的提交有冲突,解决办法也很简单,Git已经提示我们,先用git pull把最新的提交从origin/dev抓下来,然后,在本地合并,解决冲突,再推送:

$ git pull
There is no tracking information for the current branch.
Please specify which branch you want to merge with.
See git-pull(1) for details.

    git pull <remote> <branch>

If you wish to set tracking information for this branch you can do so with:

    git branch --set-upstream-to=origin/<branch> dev

git pull也失败了,原因是没有指定本地dev分支与远程origin/dev分支的链接,根据提示,设置dev和origin/dev的链接:

$ git branch --set-upstream-to=origin/dev dev
Branch ‘dev‘ set up to track remote branch ‘dev‘ from ‘origin‘.

再pull:

$ git pull
Auto-merging env.txt
CONFLICT (add/add): Merge conflict in env.txt
Automatic merge failed; fix conflicts and then commit the result.

这回git pull成功,但是合并有冲突,需要手动解决,解决的方法和分支管理中的解决冲突完全一样。解决后,提交,再push:

$ git commit -m "fix env conflict"
[dev 57c53ab] fix env conflict

$ git push origin dev
Counting objects: 6, done.
Delta compression using up to 4 threads.
Compressing objects: 100% (4/4), done.
Writing objects: 100% (6/6), 621 bytes | 621.00 KiB/s, done.
Total 6 (delta 0), reused 0 (delta 0)
To github.com:michaelliao/learngit.git
   7a5e5dd..57c53ab  dev -> dev

因此,多人协作的工作模式通常是这样:

  1. 首先,可以试图用git push origin
  • 如果推送失败,则因为远程分支比你的本地更新,需要先用git pull试图合并;

  • 如果合并有冲突,则解决冲突,并在本地提交;

  • 没有冲突或者解决掉冲突后,再用git push origin

如果git pull提示no tracking information,则说明本地分支和远程分支的链接关系没有创建,用命令git branch --set-upstream-to

这就是多人协作的工作模式,一旦熟悉了,就非常简单。

标签管理

在Git中打标签非常简单,首先,切换到需要打标签的分支上:

git branch

然后,敲命令git tag

git tag v1.0

可以用命令git tag查看所有标签:

git tag

默认标签是打在最新提交的commit上的。有时候,如果忘了打标签,比如,现在已经是周五了,但应该在周一打的标签没有打,怎么办?

方法是找到历史提交的commit id,然后打上就可以了:

git log --pretty=oneline --abbrev-commit

git tag v0.9 f52c633

注意,标签不是按时间顺序列出,而是按字母排序的。可以用git show

git show v0.9

还可以创建带有说明的标签,用-a指定标签名,-m指定说明文字:

git tag -a v0.1 -m "version 0.1 released" 1094adb

操作标签

如果标签打错了,也可以删除:

git tag -d v0.1

如果要推送某个标签到远程:

git push origin v1.0

或者,一次性推送全部尚未推送到远程的本地标签:

git push origin --tags

如果标签已经推送到远程,要删除远程标签就麻烦一点,先从本地删除:

git tag -d v0.9

git push origin :refs/tags/v0.9

使用git

别人好的项目先fork到自己的仓库,再clone到本地。

如果你想修复bootstrap的一个bug,或者新增一个功能,立刻就可以开始干活,干完后,往自己的仓库推送。

如果你希望bootstrap的官方库能接受你的修改,你就可以在GitHub上发起一个pull request。

以上是关于Git的主要内容,如果未能解决你的问题,请参考以下文章

VSCode自定义代码片段15——git命令操作一个完整流程

如何管理在每个 git 版本中添加私有代码片段?

使用 Git 来管理 Xcode 中的代码片段

markdown Git代码片段

GitGit 分支管理 ( 克隆远程分支 | 克隆 master 分支 git clone | 查看远程分支 git branch -a | 克隆远程分支 git checkout -b )(代码片段

GitGit 分支管理 ( 克隆远程分支 | 克隆 master 分支 git clone | 查看远程分支 git branch -a | 克隆远程分支 git checkout -b )(代码片段