分布式版本控制工具 - Git

135 阅读1分钟

Git操作流程

代码提交流程图 image.png 代码撤销流程图 image.png

Git常用命令\

配置信息

$ git config --global user.name "<name>"
$ git config --global user.email "<email address>"

仓库初始化

cd your_path
$ git init #仓库初始化
$ git remote add <name> <git-repo-url> #添加远程仓库
$ git remote -v #查看远程仓库
$ git remote set-url origin <your-git-url> #替换仓库地址

$ git clone ssh:your_path/xx.git

历史版本

$ git log --graph --decorate --abbrev-commit --all #查看历史版本
$ git checkout a5d88ea #切换历史版本

代码提交和拉取/合并

$ git status #查看状态
$ git add --all # 当前项目下的所有更改
$ git add .  # 当前目录下的所有更改
$ git add xx/xx.txt  # 添加某几个文件

$ git commit -m"<这里写commit的描述>"
$ git push -u origin master # 第一次需要关联上

$ git push # 之后再推送就不用指明应该推送的远程分支了
$ git branch # 可以查看本地仓库的分支
$ git branch -a # 可以查看本地仓库和本地远程仓库(远程仓库的本地镜像)的所有分支

$ git checkout branch #切换分支
$ git checkout -b branch #当你在当前分支做了修改,又不想提交,可以创建一个新的分支

$ git pull/fetch #拉取代码

本地有修改时,使用git stash暂存修改
$ git stash # 工作区修改暂存
$ git pull  # 更新分支
$ git stash pop # 暂存修改恢复到工作区

$ git merge branch_name #合并代码

代码撤销

just updated
$ git diff # 列出所有的修改 
$ git diff xx/xx.txt xx/xx2.txt # 列出某(几)个文件的修改 
$ git checkout # 撤销项目下所有的修改 
$ git checkout . # 撤销当前文件夹下所有的修改 
$ git checkout xx/xx.txt xx/xx2.txt # 撤销某几个文件的修改 
$ git clean -f # untracked状态,撤销新增的文件 
$ git clean -df # untracked状态,撤销新增的文件和文件夹

just added
$ git diff --cached # 这个命令显示暂存区和本地仓库的差异

$ git reset # 暂存区的修改恢复到工作区
$ git reset --soft # 与git reset等价,回到已修改状态,修改的内容仍然在工作区中
$ git reset --hard # 回到未修改状态,清空暂存区和工作区

just committed
$ git diff <branch-name1> <branch-name2> # 比较2个分支之间的差异
$ git diff master origin/master # 查看本地仓库与本地远程仓库的差异

$ git reset --hard origin/master # 回退与本地远程仓库一致
$ git reset --hard HEAD^ # 回退到本地仓库上一个版本
$ git reset --hard <hash code> # 回退到任意版本
$ git reset --soft/git reset # 回退且回到已修改状态,修改仍保留在工作区中。

$ git revert <commit-hash> # 去除某个commit,实质是新建了一个与原来完全相反的commit,抵消了原来commit的效果

already pushed
$ git push -f orgin master # 强制覆盖远程分支
$ git push -f # 如果之前已经用 -u 关联过,则可省略分支名

$ git revert <commit-hash> # 实质是新建了一个与原来完全相反的commit,抵消了原来commit的效果