Your Site Name

git常用命令与常见面试题汇总

2024年4年5日 · 1043

标签:

这篇文章讲述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命令

常用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历史。