Git 常用指令面试题

 

  • 全局配置
  • git config --global user.name '你的名字'
  • git config --global user.email '你的邮箱'

 

  • 当前仓库配置
  • git config --local user.name '你的名字'
  • git config --local user.email '你的邮箱'

 

  • 查看global配置
  • git config --global --list
  • 查看仓库配置
  • git config --local --list
  • 删除global配置
  • git config --unset --global 要删除的配置
  • 删除当前仓库的配置
  • git config --unset --local 要删除的配置

 

 

  • 本地操作
  • 查看变更状况
  • git status

 

  • 将目录及其子目录下所有变更都加入到在暂存区
  • git add.

 

  • 将仓库内所有变更都加入到暂存区
  • git add -A

 

  • 将指定文件添加到暂存区
  • git add 文件1 2 3

 

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

 

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

 

  • 比较暂存区和HEAD的所有差异
  • git diff --cached

 

  • 比较某文件暂存区和HEAD的差异
  • git diff --cached 文件

 

  • 比较某文件工作区和HEAD的差异
  • git diff HEAD 文件

 

  • 创建commit
  • git commit

 

  • 将工作区指定文件恢复成和暂存区一致
  • git checkout 文件1 2 3

 

  • 将暂存区指定文件恢复成和HEAD一致
  • git reset 文件 1 2 3

 

  • 将暂存区和工作区所有文件恢复成和HEAD一样
  • git reset --head

 

  • 用difftool 比较任意两个commit的差异
  • git difftool 提交1 提交2

 

  • 查看哪些文件没被Git管控
  • git ls-files --others

 

  • 将未处理完的变更保存到stash中
  • git stash

 

  • 临时任务处理完后继续之前的文件
  • git stash pop pop不保留stash
  • git stash apply apply保留stash

 

  • 查看所有stash
  • git stash list

 

  • 取回某次stash的变更
  • git stash pop stash@{数字n}

 

  • 优雅修改最后一次commit
  • git add.
  • git commit --amend

 

 

  • 分支操作
  • 查看当前工作分支以及本地分支
  • git branch -v
  • 查看本地和远地分支
  • git branch -av
  • 切换到指定分支
  • git checkout 指定分支
  • 基于当前分支创建新的分支
  • git branch 新分支
  • 基于指定分支创建新的分支
  • git branch 新分支 指定分支
  • 基于某个commit创建分支
  • git branch 新分支 某个commit的id
  • 创建并切换到该分支
  • git checkout -b新分支
  • 安全删除本地某分支
  • git branch -d某分支
  • 删除远端 origin 已不存在的所有本地分支
  • git remote prune origin
  • 将 A 分支合入到当前分支中且为 merge 创建 commit
  • git merge A
  • 将 A 分支合入到 B 分支中且为 merge 创建 commit
  • git merge A B
  • 将当前分支基于 B 分支做 rebase,以便将B分支合入到当前分支
  • git rebase B
  • 将 A 分支基于 B 分支做 rebase,以便将 B 分支合入到 A 分支
  • git rebase B A

 

  • 当前分支各个 commit 用一行显示
  • git log --oneline
  • 显示就近的 n 个 commit
  • git log -n
  • 用图示显示所有分支的历史
  • git log --oneline --graph --all
  • 查看涉及到某文件变更的所有 commit
  • git log文件
  • 某文件各行最后修改对应的 commit 以及作者
  • git blame 文件

 

标签操作

  • 查看已有标签
  • git tag
  • 新建标签
  • git tag v1.0
  • 新建带备注标签
  • git tag -a v1.0 -m'xxx'
  • 给指定的 commit 打标签
  • git tag v1.0 commitid
  • 推送一个本地标签
  • git push origin v1.0
  • 推送全部未推送过的本地标签
  • git push origin --tags
  • 删除一个本地标签
  • git tag -d v1.0
  • 删除一个远端标签
  • git push origin :refs/tags/v1.0

 

远端交互

  • 查看所有远端仓库
  • git remote -v
  • 添加远端仓库
  • git remote add url
  • 删除远端仓库
  • git remote remove 仓库名
  • 重命名远端仓库
  • git remote rename 仓库名
  • 将远端所有分支和标签的变更都拉到本地
  • git fetch remote
  • 把远端所有分支的变更拉到本地,且 merge 到本地分支
  • git pull origin 分支名
  • 将本地分支 push 到远端
  • git push origin 分支名
  • 删除远端分支
  • git push remote --delete远端分支名

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值