程序员波特的个人博客

一个小而美的程序员编程资料站

0%

Git 相关面试题

一、配置操作

1. 全局配置

1
2
3
git config --global user.name '你的名字'
git config --global user.email '你的邮箱'

2. 当前仓库配置

1
2
3
git config --local user.name '你的名字'
git config --local user.email '你的邮箱'

3.查看 global 配置

1
2
git config --global --list

4. 查看当前仓库配置

1
2
git config --local --list

5. 删除 global 配置

1
2
git config --unset --global 要删除的配置项

6. 删除当前仓库配置

1
2
git config --unset --local 要删除的配置项


二、本地操作

1. 查看变更情况

1
2
git status

2. 将当前目录及其子目录下所有变更都加入到暂存区

1
2
git add .

3. 将仓库内所有变更都加入到暂存区

1
2
git add -A

4. 将指定文件添加到暂存区

1
2
git add 文件1 文件2 文件3

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

1
2
git diff

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

1
2
git diff 文件

7. 比较暂存区和 HEAD 的所有差异

1
2
git diff --cached

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

1
2
git diff --cached 文件

9. 比较某文件工作区和 HEAD 的差异

1
2
git diff HEAD 文件

10. 创建 commit

1
2
git commit

11. 将工作区指定文件恢复成和暂存区一致

1
2
git checkout 文件1 文件2 文件3

12. 将暂存区指定文件恢复成和 HEAD 一致

1
2
git reset 文件1 文件2 文件3

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

1
2
git reset --hard

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

1
2
git difftool 提交1 提交2

15. 查看哪些文件没被 Git 管控

1
2
git ls-files --others

16. 将未处理完的变更先保存到 stash 中

1
2
git stash

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

  • pop 不保留 stash
  • apply 保留 stash
1
2
3
git stash pop
git stash apply

18. 查看所有 stash

1
2
git stash list

19. 取回某次 stash 的变更

1
2
3
4
git stash pop stash@{

数字n}

20. 优雅修改最后一次 commit

1
2
3
git add.
git commit --amend


三、分支操作

1. 查看当前工作分支及本地分支

1
2
git branch -v

2. 查看本地和远端分支

1
2
git branch -av

3. 查看远端分支

1
2
git branch -rv

4. 切换到指定分支

1
2
git checkout 指定分支

5. 基于当前分支创建新分支

1
2
git branch 新分支

6. 基于指定分支创建新分支

1
2
git branch 新分支 指定分支

7. 基于某个 commit 创建分支

1
2
git branch 新分支 某个 commit 的 id

8. 创建并切换到该分支

1
2
git checkout -b 新分支

9. 安全删除本地某分支

1
2
git branch -d 要删除的分支

10. 强行删除本地某分支

1
2
git branch -D 要删除的分支

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

1
2
git branch --merged master | grep -v '^\*\| master' | xargs -n 1 git branch -d

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

1
2
git remote prune orign

13. 将 A 分支合入到当前分支中且为 merge 创建 commit

1
2
git merge A分支

14. 将 A 分支合入到 B 分支中且为 merge 创建 commit

1
2
git merge A分支 B分支

15. 将当前分支基于 B 分支做 rebase,以便将B分支合入到当前分支

1
2
git rebase B分支

16. 将 A 分支基于 B 分支做 rebase,以便将 B 分支合入到 A 分支

1
2
git rebase B分支 A分支


四、变更历史

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

1
2
git log --oneline

2. 显示就近的 n 个 commit

1
2
git log -n

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

1
2
git log --oneline --graph --all

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

1
2
git log 文件

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

1
2
git blame 文件


五、标签操作

1. 查看已有标签

1
2
git tag

2. 新建标签

1
2
git tag v1.0

3. 新建带备注标签

1
2
git tag -a v1.0 -m '前端食堂'

4. 给指定的 commit 打标签

1
2
git tag v1.0 commitid

5. 推送一个本地标签

1
2
git push origin v1.0

6. 推送全部未推送过的本地标签

1
2
git push origin --tags

7. 删除一个本地标签

1
2
git tag -d v1.0

8. 删除一个远端标签

1
2
git push origin :refs/tags/v1.0


六、远端交互

1. 查看所有远端仓库

1
2
git remote -v

2. 添加远端仓库

1
2
git remote add url

3. 删除远端仓库

1
2
git remote remove remote的名称

4. 重命名远端仓库

1
2
git remote rename 旧名称 新名称

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

1
2
git fetch remote

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

1
2
git pull origin 分支名

7. 将本地分支 push 到远端

1
2
git push origin 分支名

8. 删除远端分支

1
2
3
git push remote --delete 远端分支名
git push remote :远端分支名