git常用命令与常见面试题汇总
这篇文章讲述git框架,总结常用git命令及开发中的常见问题
git框架介绍
Git 框架结构及各区域关系:Git 的核心结构分为四个关键区域,它们协同工作实现版本控制:
1. Workspace(工作区)
- 定义:开发者直接操作的本地目录(可见文件系统)
- 内容:当前可见的文件/目录(包含已跟踪和未跟踪文件)
- 特点:所有修改首先发生在这里
2. Index / Stage(暂存区/缓存区)
- 定义:临时存储待提交修改的缓冲区
- 内容:通过
git add
添加的文件快照 - 特点:充当工作区和仓库区的过渡层
3. Repository(仓库区/本地仓库)
- 定义:存储项目完整历史的数据库
- 内容:
- 提交历史(commit objects)
- 分支/标签指针(.git/refs)
- 元数据(.git 目录)
- 核心文件:
HEAD
:指向当前分支objects
:存储所有 Git 对象(blob/tree/commit)
4. Remote(远程仓库)
- 定义:云端共享仓库(如 GitHub/GitLab)
- 内容:其他成员可访问的中央代码库
- 特点:通过 URL 标识(
origin
为默认别名)
常用git命令

常见问题
1. 隔离设计价值:
- 暂存区允许选择性提交
- 本地仓库保证离线工作能力
- 远程仓库实现团队协作
2. 提交时发生冲突,如何解决?
为什么会产生冲突?
在合并分支的时候,master分支和dev分支恰好有人都修改了同一个文件,GIT不知道应该以哪一个人的文件为准,所以就产生了冲突了。 两个分支相同文件相同位置的的不同操作!
如何解决?
发生冲突,在IDE里面对比本地文件和远程分支的文件,然后把远程分支上文件的内容手工修改到本地文件,然后再提交冲突的文件使其保证与远程分支的文件一致,消除冲突,然后再提交自己修改的部分。
- 通过git stash命令,把工作区的修改提交到栈区,目的是保存工作区的修改;
- 通过git pull命令,拉取远程分支上的代码并合并到本地分支,目的是消除冲突;
- 通过git stash pop命令,把保存在栈区的修改部分合并到最新的工作空间中;
3. 新建git功能分支的步骤?
- Git branch name 创建名字为name的branch
- Git checkout xxx_dev 切换到名字为xxx_dev的分支
- Git pull 从远程分支拉取代码到本地分支
- Git checkout -b main_furture_xxx 创建并切换到 main_furture_xxx 分支
- Git push origin main_furture_xxx 执行推送的操作,完成本地分支向远程分支的同步
在执行git pull的时候,提示当前branch没有跟踪信息:
- git pull origin 远程分支名称
- git branch --set-upstream-to=origin/远程分支名称 本地分支名 (先建立远程分支与本地分支的连接,再pull)
- git pull 再次pull
4. fork、 branch、clone 之间的区别?
- fork:是对存储仓库(repository)进行的远程的,服务器端的拷贝。复刻不是git范畴。
- clone:不是复刻,克隆是对某个远程仓库的本地拷贝。克隆时,实际上是拷贝整个存储仓库,包括所有的历史记录和分支。
- branch:是一种机制,用于处理单一存储仓库中的变更,并最终目的是用于与其他部分代码合并。
5. 说明GIT合并的两种方法以及区别
Git代码合并有两种:Git Merge 和 Git ReBase
-
Git Merge:这种合并方式是将两个分支的历史合并到一起,现在的分支不会被更改,它会比对双方不同的文件缓存下来,生成一个commit,去push。
-
Git ReBase:这种合并方法通常被称为“衍合”。他是提交修改历史,比对双方的commit,然后找出不同的去缓存,然后去push,修改commit历史。