IntelliJ IDEA 下玩转 Git !#yyds干货盘点#
Posted 码农小宋
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了IntelliJ IDEA 下玩转 Git !#yyds干货盘点#相关的知识,希望对你有一定的参考价值。
有一天我看见我们公司的同事在讨论合并代码怎么怎么不舒服,不方便。就是每次合并都很难搞的样子。我说 这不是用 Idea 很简单就处理好了吗。后面我了解到,他们在处理代码冲突的时候都是通过手动处理冲突的。我惊了!
2019 年的时候 我在知乎回答过一篇 关于 Idea 技巧的一篇文章。不过那个时候更多是一些快捷键操作的一些奇淫技巧。
对 Git 版本管理这块讲的不多。在 2 年后的今天,被我们现在的同事刺激了一下,自己决定完善一下 Idea 下 Git 版本的操作他们。
Git 派系介绍
其实在公司里面 Git 管理这块也是分为几大派系的黑窗一个黑窗走天下,任何工具都是花里胡哨。
所有的操作都是通过命令行完成。个人愚见:这种方式虽然很酷很帅,但是毕竟只有一个黑窗,在某些场景下还是比较难处理,比如 历史代码查看,代码合并,变更文件详细内容查看。虽然很帅但是不适合我这种菜鸡。
source tree
source tree 是我见过用的人最多的,很多同事都是使用这个。而且还可以安装 git flow 插件,可以在里面直接使用 git flow 的工作流。我也在用,不过用的不多,每个人喜好不同,有的同事喜欢代码版本管理和代码编写分开,我自己的话恰恰喜欢放在一起。哈哈哈哈哈 萝卜青菜 各有所爱。功能很全面,但有一个问题,可能就是查看单文件或者文件夹的 历史不是很方便
Github Desktop
Github Desktop 俗称 Github 亲儿子。很早之前用过 跟 Source Tree 差不多,偶尔看到一个同事在使用这个。还是那个版本管理与代码编写的问题。如果平常使用 Github 查看源码比较多的还是推荐,因为安装了这个软件之后,可以直接在 Github 上有一个按钮 Open in Github Desktop。亲儿子才有的待遇然后才是使用 Idea 管理版本
我自己感觉 Idea 的版本管理挺好用的,但是在工作中,除了我自己,我还没有看见其他人使用过。
不过工具本来就没有最好的,只有最适合你自己的,我个人使用 Idea 下的版本管理比较顺手一点,就在这里简单介绍一下。
查看这行代码是谁改的
在编辑器左侧右键,选择 Annotate with Git Blame
点击 左侧时间会在弹出的子窗口中显示这次修改的 hash,提交评论,和同步修改的文件有哪些
复现代码冲突
这里需要重点讲一下,因为我最近居然发现我们的同事居然还是用非常原始的方式解决冲突,就是一个文件一个文件的删除 ======= 这个。当时我看见的时候,我自己都惊呆了。我们先手动的制造一个冲突
mkdir test;
cd test;
git init -y;
echo console.info("one line") > index.js;
git add .; git commit -m init;
git checkout -B feature/two;
vim index.js; # 在第二行添加 console.info("two line")
git add index.js; git commit -m feat: two line;
git branch master;
# 创建分支 3
git checkout -B feature/three;
vim index.js; # 在第二行添加 console.info("three line")
git add index.js; git commit -m feat: three line;
git checkout master
# merge feature/two
git merge feature/two # 这个时候不会发生冲突
git merge feature/threee # 冲突发生
上图展示了发生冲突的所有过程
解决冲突
上面我们已经制造出了一个冲突,这个时候我们通过 Inteillj Idea 自带的 Version Controller 的功能来处理这个冲突。直接在编辑器中打开冲突文件夹这里会有一个问题,就是在真正的项目场景下,项目文件非常的多。
在项目文件上右键,选择 Git,选择 Resolve Conflicts
点击之后会弹出一个处理冲突的弹窗。接下来好好介绍一下这个弹窗
- 1. 待合并分支
- 2. 当前分支
- 3. 冲突的文件列表
- 4. 全部以当前分支「master」为准,丢弃待合并「feature/three」分支冲突文件
- 5. 全部以待合并分支「feature/three」为准,丢弃当前分支「master」冲突文件
- 6. 点击 merge 会打开一个子窗口合并明细
- 7. 双击文件和打开一个子窗口进行代码 merge 明细
- 8. 显示了合并分支文件状态,上图标识合并的两个分支 文件都是更新状态
- 9. 以分组列表的形式展示
这里就进入到详细的单文件合并步骤了
- 1️⃣ 当前分支的修改
- 2️⃣ 合并区域
- 3️⃣ 待合并分支的修改
- 4️⃣ 显示本次合并的明细,就是看除了当前文件还有哪些文件需要合并
- 5️⃣ 将左侧
console.info("two line")
合并 - 6️⃣ 将右侧
console.info("three line")
合并 - 7️⃣ 直接接受左侧的代码
- 8️⃣ 直接接受右侧的代码
- 9️⃣ 引用合并的内容
查看代码历史
点击 Show History
点击 Show History 之后底部会弹出当前项目的历史提交记录
- 1️⃣ 这里显示的当前项目的提交记录
- 2️⃣ 可以指定想要查看历史记录的分支
- 3️⃣ 可以选择只看某个人的提交记录
- 4️⃣ 时间赛选
- 5️⃣ 选中左侧的提交记录,这里会展示此次变更了哪些文件,双击文件会在弹出的新窗口中显示代码变更情况
上面是直接选中的整个项目查看整个项目的历史提交记录,有的时候我们只想查看某个文件夹,或者是某个文件的代码变更记录。整个时候我们只需要在对应的文件夹或者文件上右键悬着即可。
分支创建
根据实际工作场景出发,先列举一下会创建分支的集中情况。在实际的应用场景来看如果用 Idea 来解决。
- 开发新功能,我们需要从现有分支创建新的 feature 分支
- 我们正在开发 feature 分支,但是此时线上出 Bug,我们需要从 master 分支创建 hotfix 分支来修复
- 我们在浏览源代码,我们浏览代码历史上某个版本的代码
从现有分支创建新的 feature 分支,这是最简单的,甚至都不需要用 idea 了,代码也是一行搞定 git checkout -B feature/xxx
直接从项目上直接右键创建即可
- 我们正在开发 feature 分支,但是此时线上出 Bug,我们需要从 master 分支创建 hotfix 分支来修复
这种情况其实是正式项目中的常态吧,毕竟线上环境是复杂的,问题随时都会发生。但是问题就是可能我们现在开发的 feature 分支还没有开发完成,我们自己也不想用 commit 进行提交。这个时候就需要用到 git 的 stash 功能了。在切换前先 Stash Changes,将目前修改的代码暂存
在弹窗中给这次暂存添加 备注 然后点击 create stash在处理好 stash 之后我们需要切回到 master 分支去创建对应的 hotfix 分支
点击 Branchs
选择 master 分支进行切换,切换后创建对应hotfix 分支,在修复好 hotfix 分之后,我们需要回到对应的 feature 分支继续开发未开发完成的功能。
选择 Unstash Changes
这里会有自己存储的 stash 历史,点击 apply stash 进行恢复
- 我们在浏览源代码,我们浏览代码历史上某个版本的代码
添加修改「git add xxx」
我们每次新增的代码需要通过 git add xxx 命令将代码从工作区添加到缓存区上面的 add.js 文件是我们新添加的文件
提交修改「git commit xxx」
点击 Commit Directory
以上是关于IntelliJ IDEA 下玩转 Git !#yyds干货盘点#的主要内容,如果未能解决你的问题,请参考以下文章
RingCentral Tech | Scrum框架下玩转敏捷实践
Linux下玩转nginx系列---nginx日志配置文件说明