工作之后,公司使用 SourceTree 来管理代码,然后我也不明白 SVN、Git、SourceTree 有啥联系,后来知道了 SourceTree 是 Git 的图形界面,用它来管理代码真的非常方便。然后看了廖雪峰的 Git 教程,知道了 Git 的诞生和与 SVN 之间的区别,也知道 SoureTree 上的一些操作用命令如何去实现,然后总结归纳了一下文章。具体参考廖雪峰的git教程。
常用命令
-
创建 git 仓库:
git init
-
添加文件到Git仓库,分两步:
git add <file>
git commit -m <message>
-
查看工作区状态
git status
-
如果工作区有文件改动,可以查看改动内容
git diff <file>
-
查看提交历史
git log
git log --pretty=oneline
-
返回到上一个提交
git reset --hard HEAD^
-
查看命令历史,以便确定要回到未来的版本
git reflog
-
恢复到某一个提交
git reset --hard <commitId>
-
撤销修改,把工作区恢复到最近一次 git commit 或者 git add 时到状态
git checkout -- <file>
-
用命令
git reset HEAD
可以把暂存区的修改撤销掉(unstage),重新放回工作区git reset HEAD <file>
-
删除一个文件
git rm <file>
-
贮藏工作区的代码
git stash
-
查看贮藏列表
git stash list
-
使用贮藏区的代码
一是用
git stash apply
恢复,但是恢复后,stash内容并不删除,你需要用git stash drop
来删除;另一种方式是用
git stash pop
,恢复的同时把stash内容也删了。 -
如果你多次stash,可以恢复到指定的stash
git stash apply stash@{0}
-
遴选某一次提交
git cherry-pick <commit>
远程仓库
-
要关联一个远程库,使用命令
git remote add origin git@server-name:path/repo-name.git
;关联后,使用命令
git push -u origin master
第一次推送master分支的所有内容;此后,每次本地提交后,只要有必要,就可以使用命令
git push origin master
推送最新修改。 -
要克隆一个仓库,首先必须知道仓库的地址,然后使用
git clone
命令克隆。Git支持多种协议,包括
https
,但通过ssh
支持的原生git
协议速度最快。
分支管理
-
Git鼓励大量使用分支:
查看分支:
git branch
创建分支:
git branch <name>
切换分支:
git checkout <name>
或者git switch <name>
创建+切换分支:
git checkout -b <name>
或者git switch -c <name>
合并某分支到当前分支:
git merge <name>
删除分支:
git branch -d <name>
(新版本 git 才能够使用 switch)
-
当Git无法自动合并分支时,就必须首先解决冲突。解决冲突后,再提交,合并完成。
解决冲突就是把Git合并失败的文件手动编辑为我们希望的内容,再提交。
用
git log --graph
命令可以看到分支合并图。合并分支时,加上
--no-ff
参数就可以用普通模式合并,合并后的历史有分支,能看出来曾经做过合并,而fast forward
合并就看不出来曾经做过合并。
多人协作
查看远程库信息,使用
git remote -v
;本地新建的分支如果不推送到远程,对其他人就是不可见的;
从本地推送分支,使用
git push origin branch-name
,如果推送失败,先用git pull
抓取远程的新提交;在本地创建和远程分支对应的分支,使用
git checkout -b branch-name origin/branch-name
,本地和远程分支的名称最好一致;建立本地分支和远程分支的关联,使用
git branch --set-upstream branch-name origin/branch-name
;从远程抓取分支,使用
git pull
,如果有冲突,要先处理冲突。rebase操作可以把本地未push的分叉提交历史整理成直线;
rebase的目的是使得我们在查看历史提交的变化时更容易,因为分叉的提交需要三方对比。