目录
Git 的基本概念
Git 安装与配置
Git 常用命令与操作
1. 初始化本地仓库
2. 版本控制工作流程
3. 分支管理
4. 解决冲突
5. 回退和撤销
6. 查看提交日志
前言
在软件开发过程中,开发者常常需要在现有程序的基础上进行修改和扩展。但如果不加以管理,很容易出现以下两种问题:
- 担心修改错误:怕修改了代码后,原始文件也被弄坏。
- 版本混乱:每次修改后,我们都需要保存一个副本,但随着修改的增多,版本数量也随之增加,如何管理这些版本成了难题。
为了解决这些问题,版本控制工具应运而生。Git 是其中最流行的一个,它能帮助我们高效地管理代码版本,确保项目开发过程中的每一步都可追溯、可恢复。
Git 的基本概念
Git 是一个分布式版本控制系统,用于跟踪文件的变化,尤其是在多人协作开发时显得尤为重要。它提供了一个清晰的工作流程,能够让每个人都保持同步并避免冲突。
1. Git 的工作区和仓库
Git 的工作区域包含以下几个部分:
- 工作区 (Working Directory):即你本地的代码文件夹,开发者在这里进行编码。
- 暂存区 (Staging Area):你已经修改并准备提交的文件。通过
git add
命令可以把文件加入暂存区。 - 本地仓库 (Local Repository):本地保存的版本库,提交的内容存储在这里。
- 远程仓库 (Remote Repository):如 GitHub、GitLab 等托管代码的服务器,团队成员可以从中拉取(pull)或推送(push)代码。
Git 安装与配置
-
下载 Git
前往 Git 官网下载安装包,根据操作系统选择对应版本。 Git 官网https://git-scm.com/downloadshttps://git-scm.com/downloadshttps://git-scm.com/downloads -
安装 Git
安装过程有较多的配置项,界面如何勾选请参考这篇博客,如下:
。。。未完成。。
-
配置 Git 用户信息
安装后,需要配置 Git 的全局用户名和邮箱,确保每次提交记录时能够标记出具体的用户。git config --global user.name "Your Name" git config --global user.email "email@example.com"
-
配置 SSH 密钥
为了方便与远程仓库(如 GitHub、GitLab 等)进行交互,我们需要配置 SSH 密钥。ssh-keygen -t rsa # 按提示生成 SSH 密钥 cat ~/.ssh/id_rsa.pub # 将生成的公钥复制到远程仓库的 SSH 密钥配置中
Git 常用命令与操作
1. 初始化本地仓库
git init # 初始化一个空的 Git 仓库
2. 版本控制工作流程
-
将文件添加到暂存区:
git add . # 添加当前目录下所有文件 git add fileName # 添加某个指定文件
-
提交修改到本地仓库:
git commit -m "提交备注"
-
查看状态:
git status # 查看当前仓库的状态
-
推送本地修改到远程仓库:
git push # 推送到远程仓库
-
拉取远程仓库的修改:
git pull # 拉取远程仓库最新的修改
3. 分支管理
Git 允许我们在不同的分支上进行开发,分支操作使得多个开发者可以并行工作,而不会互相影响。
-
查看本地分支:
git branch # 查看所有本地分支
-
创建并切换到新分支:
git checkout -b new-branch # 创建并切换到新分支
-
切换到已存在的分支:
git checkout existing-branch # 切换到指定的分支
-
合并分支:
git checkout master # 切换到 master 分支 git merge new-branch # 合并新分支到 master
-
删除分支:
git branch -d branch-name # 删除本地分支 git push origin --delete branch-name # 删除远程分支
4. 解决冲突
出现CONFLICT => 表明该文件有冲突,被至少2人修改。
解决方法:
- 查看日志,去线下和对应修改人员沟通,确定如何修改。
- 切忌在协作开发时,随意修改或者删除他人代码
下面为大家演示一个冲突解决案例:
① 现在我们在新建一个分支,dev1
git checkout -b dev1
② 查看:
$ git branchdev
* dev1master
③ 我们在div1分支下,对文件里边的内容进行修改
④ 然后上传:
git add .
git commit -m"div1进行提交"
git checkout master
git merge dev1
git push
⑤ 上传成功之后,我们在切换到dev分支之下,我们可以看到 div 分支下的文件内容 已经和dev1分支下的文件中的内容不一致了,现在我们重写一个新的内容
⑥ 同样进行上传,然后当我们在合并分支的时候会出现CONFLACT冲突,如下图:
⑦ 打开我们的文件,可以看到git自动帮我们标记出了具体的冲突内容:
⑧ 产生冲突后,我们必须手动解决冲突,只需要我们保留我们想要的结果
⑨ 更改完错误以后需要我们commit提交,然后上传
造成冲突的原图:
在不同分支之下,更改了相同的文件
5. 回退和撤销
-
撤销未提交的修改:
git checkout fileName # 撤销某个文件的修改 git checkout . # 撤销所有文件的修改
-
回退到上一个提交:
git reset --hard HEAD^ # 回退到上一个版本
6. 查看提交日志
-
查看提交历史:
git log # 查看详细的提交日志 git log --oneline # 简洁格式查看提交历史
-
查看命令历史:
git reflog # 查看 Git 命令历史
总结
Git 是一个强大的版本控制工具,它能够帮助开发者高效地管理代码版本,追踪代码修改,避免版本冲突,并且支持多人协作开发。掌握 Git 的基本操作和工作流程对于现代软件开发至关重要。如果你刚刚开始接触 Git,建议多练习命令行操作,理解每一个命令的意义,逐步建立起版本控制的思维方式。
希望本文能帮助你更好地理解 Git,并使用它进行版本管理和团队协作。