前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >鼠标垫上的Git知识库

鼠标垫上的Git知识库

作者头像
CrazyCodes
发布2021-01-14 14:17:47
3710
发布2021-01-14 14:17:47
举报
文章被收录于专栏:Grace developmentGrace development

前言

Hello,大家好,我是CrazyCodes,之前在极客时间上买过一个git鼠标垫,感觉其知识点展示的非常干练,现手敲分享给大家,文末有购买链接。

Git最小配置

某账号下所有的Git仓库都有效

代码语言:javascript
复制
git config --global user.name '您的名称'
git config --global user.email '您的Email'

只对当前Git仓库有效

代码语言:javascript
复制
git config --local user.name '您的名称'
git config --local user.email '您的Email'

查看Git的配置

查看global类型的配置项

代码语言:javascript
复制
git config --global --list

查看只作用于当前仓库的配置项

代码语言:javascript
复制
git config --local --list

清除Git的配置

清除global类型的配置项

代码语言:javascript
复制
git config --unset --global 某个配置项

清除某个仓库的配置项

代码语言:javascript
复制
git config --unset --local 某个配置项

本地基本操作

查看变更情况

代码语言:javascript
复制
git status

查看当前工作在哪个分支上

代码语言:javascript
复制
git branch -v

切换到指定分支

代码语言:javascript
复制
git checkout 指定分支

把当前目录及其目录下所有变更都加入到暂存区

代码语言:javascript
复制
git add .

把仓库内所有变更都加入暂存区

代码语言:javascript
复制
git add -A

把指定文件添加到暂存区

代码语言:javascript
复制
git add 文件1 文件2 文件3

创建正式的commit

代码语言:javascript
复制
git commit 

比较某文件工作区和暂存区的差异

代码语言:javascript
复制
git diff 某文件

比较某文件暂存区和HEAD的差异

代码语言:javascript
复制
git diff HEAD 某文件

比较工作区和暂存区的所有差异

代码语言:javascript
复制
git diff --cached

把工作区指定文件恢复成和暂存区一样

代码语言:javascript
复制
git checkout 文件1 文件2 文件3

把暂存区指定文件恢复成和HEAD一样

代码语言:javascript
复制
git reset 文件1 文件2 文件3

把暂存区和工作区所有文件恢复成和HEAD一样

代码语言:javascript
复制
git reset --hard

用difftool比较任意两个commit的差异

代码语言:javascript
复制
git difftoll 提交A 提交B

查看哪些文件没被Git管控

代码语言:javascript
复制
git is-files --others

加塞临时任务的处理

把未处理完的变更先保存到stash中

代码语言:javascript
复制
git stash

临时任务处理完后继续之前未完的工作

代码语言:javascript
复制
git stash pop
或者
git stash apply

pop不保留stash,apply保留stash

查看所有的stash

代码语言:javascript
复制
git stash list

取回某次stash的变更

代码语言:javascript
复制
git stash pop stash@{数字n}

修改个人分支的历史

修改最后一次commit

  1. 在工作区修改文件
  2. git add .
  3. git commit --amend

修改中间的commit(代号x)

  1. git rebase -i X前面一个commit的id
  2. 在工作区修改文件
  3. git add .
  4. git rebase --continue 后续可能需要处理冲突,直到rebase结束

查看变更历史

当前分支各个commit用一行显示

代码语言:javascript
复制
git log --oneline

显示就近的n个commit

代码语言:javascript
复制
git log -n

用图示显示所有分支的历史

代码语言:javascript
复制
git log --oneline --graph --all

查看涉及到某文件变更的所有commit

代码语言:javascript
复制
git log 某文件

某文件各行最后修改对应的commit 以及作者

代码语言:javascript
复制
git blame 某文件

分支与标签

基于当前分支创建新分支

代码语言:javascript
复制
git branch 新分支

基于指定分支创建新分支

代码语言:javascript
复制
git branch 新分支 已有分支

基于某个commit创建分支

代码语言:javascript
复制
git branch 新分支 某个commit的id

创建分支并切换到该分支

代码语言:javascript
复制
git checkout -b 新分支

列出本地分支

代码语言:javascript
复制
git branch -v

列出本地和远端分支

代码语言:javascript
复制
git branch -av

列出远端所有分支

代码语言:javascript
复制
git branch -rv

列出名称符合某样式的远端分支

代码语言:javascript
复制
git branch -rv -l '某样式'

安全删除本地某分支

代码语言:javascript
复制
git branch -d 拟删除分支

强行删除本地某分支

代码语言:javascript
复制
git branch -D 拟删除分支

删除已合并到master分支的所有本地分支

代码语言:javascript
复制
git branch --merged master | grep -v '^\*\| master' | xargs -n 1 git branch -d

删除远端origin 已不存在的所有本地分支

代码语言:javascript
复制
git remote prune origin

给commit打上标签

代码语言:javascript
复制
git tag 标签名 commit的id

两分支之间的集成

把A分支合入到当前分支,且为merge创建commit

代码语言:javascript
复制
git merge A分支

把A分支合入到B分支,且为merge创建commet

代码语言:javascript
复制
git merge A分支 B分支

把当前分支基于B分支做rebase,以便把B分支合入到当前分支

代码语言:javascript
复制
git rebase B分支

把A分支基于B分支做rebase,以便把B分支合入到A分支

代码语言:javascript
复制
git rebase B分支 A分支

用mergetool解决冲突

代码语言:javascript
复制
git mergetool

和远端的交互

列出所有remote

代码语言:javascript
复制
git remote -v

增加remote

代码语言:javascript
复制
git remote add url地址

删除remote

代码语言:javascript
复制
git remote remove remote的名称

改变remote的name

代码语言:javascript
复制
git remote rename 旧名称 新名称

把远端所有分支和标签的变更都拉到本地

代码语言:javascript
复制
git fetch remote

把远端分支的变更拉到本地,且merge到本地分支

代码语言:javascript
复制
git pull remote 名称 分支名

把本地分支push到远端

代码语言:javascript
复制
git push remote 名称 分支名

删除远端分支

代码语言:javascript
复制
git push remote --delete 远端分支名
或者
git push remote 远端分支名

向远端提交指定标签

代码语言:javascript
复制
git push remote 标签名

向远端提交所有标签

代码语言:javascript
复制
git push remote --tags

致谢

感谢你看到这里,希望本篇文章可以帮到你,谢谢。

鼠标垫内容作者:苏玲

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Git最小配置
    • 某账号下所有的Git仓库都有效
      • 只对当前Git仓库有效
      • 查看Git的配置
        • 查看global类型的配置项
          • 查看只作用于当前仓库的配置项
          • 清除Git的配置
            • 清除global类型的配置项
              • 清除某个仓库的配置项
              • 本地基本操作
                • 查看变更情况
                  • 查看当前工作在哪个分支上
                    • 切换到指定分支
                      • 把当前目录及其目录下所有变更都加入到暂存区
                        • 把仓库内所有变更都加入暂存区
                          • 把指定文件添加到暂存区
                            • 创建正式的commit
                              • 比较某文件工作区和暂存区的差异
                                • 比较某文件暂存区和HEAD的差异
                                  • 比较工作区和暂存区的所有差异
                                    • 把工作区指定文件恢复成和暂存区一样
                                      • 把暂存区指定文件恢复成和HEAD一样
                                        • 把暂存区和工作区所有文件恢复成和HEAD一样
                                          • 用difftool比较任意两个commit的差异
                                            • 查看哪些文件没被Git管控
                                            • 加塞临时任务的处理
                                              • 把未处理完的变更先保存到stash中
                                                • 临时任务处理完后继续之前未完的工作
                                                  • 查看所有的stash
                                                    • 取回某次stash的变更
                                                    • 修改个人分支的历史
                                                      • 修改最后一次commit
                                                        • 修改中间的commit(代号x)
                                                        • 查看变更历史
                                                          • 当前分支各个commit用一行显示
                                                            • 显示就近的n个commit
                                                              • 用图示显示所有分支的历史
                                                                • 查看涉及到某文件变更的所有commit
                                                                  • 某文件各行最后修改对应的commit 以及作者
                                                                  • 分支与标签
                                                                    • 基于当前分支创建新分支
                                                                      • 基于指定分支创建新分支
                                                                        • 基于某个commit创建分支
                                                                          • 创建分支并切换到该分支
                                                                            • 列出本地分支
                                                                              • 列出本地和远端分支
                                                                                • 列出远端所有分支
                                                                                  • 列出名称符合某样式的远端分支
                                                                                    • 安全删除本地某分支
                                                                                      • 强行删除本地某分支
                                                                                        • 删除已合并到master分支的所有本地分支
                                                                                          • 删除远端origin 已不存在的所有本地分支
                                                                                            • 给commit打上标签
                                                                                            • 两分支之间的集成
                                                                                              • 把A分支合入到当前分支,且为merge创建commit
                                                                                                • 把A分支合入到B分支,且为merge创建commet
                                                                                                  • 把当前分支基于B分支做rebase,以便把B分支合入到当前分支
                                                                                                    • 把A分支基于B分支做rebase,以便把B分支合入到A分支
                                                                                                      • 用mergetool解决冲突
                                                                                                      • 和远端的交互
                                                                                                        • 列出所有remote
                                                                                                          • 增加remote
                                                                                                            • 删除remote
                                                                                                              • 改变remote的name
                                                                                                                • 把远端所有分支和标签的变更都拉到本地
                                                                                                                  • 把远端分支的变更拉到本地,且merge到本地分支
                                                                                                                    • 把本地分支push到远端
                                                                                                                      • 删除远端分支
                                                                                                                        • 向远端提交指定标签
                                                                                                                          • 向远端提交所有标签
                                                                                                                          • 致谢
                                                                                                                          领券
                                                                                                                          问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档