data:image/s3,"s3://crabby-images/12ff2/12ff2a5a0111894ae558a876db8974d882165ced" alt=""
本文介绍使用IDEA控制Git操作
关联本地Git客户端
首先要根据系统环境安装Git客户端
然后使用File –> Settings –> Version Control –> Git配置客户端安装目录
data:image/s3,"s3://crabby-images/cc283/cc283e01db335808fcfff34f8b6619839e0a0bd5" alt=""
创建本地仓库
根据项目要求创建自己的项目
然后使用VCS –> Import into Version Control –> Create Git Repository…在项目上创建Git仓库
data:image/s3,"s3://crabby-images/7fa80/7fa804e5f701be022f212c82fd31f363ec1b7e9c" alt=""
创建成功后会在项目文件夹内出现.git 目录
克隆远程仓库
我们可以通过两种方式克隆Git项目。
第一种,通过其他工具(如:Git Bash)将Git项目克隆到本地,然后使用IDEA直接打开项目。File –> Open…
第二种,使用IDEA从版本库直接导入项目。File –> New –> Project from version control –> Git
我们需要填写Git版本库URL、存储目录
data:image/s3,"s3://crabby-images/37842/378423f0b871b3a6c6e45dc61c6f56d734af7784" alt=""
提交代码
我们如果希望文件被Git管理那我们就要将文件进行add操作。
在IDEA中我们只要对某个文件设置一次add,之后就不用在手动进行add了。
文件右键 –> Git –> Add
data:image/s3,"s3://crabby-images/96ece/96ece65cb2c8743083f1359efb808412e48e13e4" alt=""
提交代码时我们使用 文件右键 –> Git –> Commit Directory…进行提交
data:image/s3,"s3://crabby-images/5f502/5f50291aebbb240d6caff4d13a8a287518b83a08" alt=""
分支管理
分支管理主要集中在IDEA的右下角操作区。
data:image/s3,"s3://crabby-images/40629/406290ea3928af37803fb9ca4d300f30babf1c50" alt=""
主菜单功能
data:image/s3,"s3://crabby-images/60673/606732fc34a8ad6052a59ae03b69f9afebeb249a" alt=""
New Branch : 从当前分支新建分支。上图就是从master分支创建新的分支。
Checkout Tag or Revision : 使用分支、标签或提交编码,检出一个临时分支。
Local Branches : 本地分支列表。同时显示对应了那个远程分支。
Remote Branches : 远程分支列表。
本地分支菜单
data:image/s3,"s3://crabby-images/5ae84/5ae840f3116597a3b79fd5f6e714e5f58b0cdff9" alt=""
Checkout : 检出这个分支。
Checkout As… : 使用这个分支创建新的分支并检出到新分支。
Compare With… : 使用当前分支与所选分支做代码提交比较。
Rebase Current onto Selected: 在当前分支做变基。(将所选分支提交加入到当前分支)
Checkout with Rebase : 检出所选分支并做变基。(将当前分支提交加入到所选分支)
Merge into Current: 合并到当前分支(将所选分支合并到当前分支)
Rname:修改所选分支名称
Delete :删除所选分支
远程分支菜单
data:image/s3,"s3://crabby-images/f6330/f633069ff18311213edb7db6a69c5be922d1c96d" alt=""
Checkout As… : 使用远程分支创建一个新的本地分支,并检出这个分支。
Compare With : 使用当前分支与所选分支做代码提交比较。
Rebase Current onto Selected : 在当前分支做变基。(将所选分支提交加入到当前分支)
Merge into Current: 合并分支(将当前分支与所选分支进行合并)
Delete :删除所选分支
本地分支推送到远程仓库
data:image/s3,"s3://crabby-images/2308a/2308a5c0f61b45e284ba6d6574c7636b0b781e0d" alt=""
检出要推送的分支,然后项目右键 –> Git –> Repository –> push
push的时候会有new标签提示会在远程新建分支
data:image/s3,"s3://crabby-images/083e3/083e315c124e36db1f1daab150861fd78ba3185f" alt=""
标签管理
检出要打标签的分支,然后Git –> Repository –> Tag…
data:image/s3,"s3://crabby-images/947a4/947a4df59fdb23049fb7f2ab40fa485d4c43dc81" alt=""
本地标签推送到远程仓库
项目右键 –> Git –> Repository –> push
data:image/s3,"s3://crabby-images/4bd6e/4bd6e946c1764991a4e0d2fbf138dee55557d175" alt=""
然后选中底部的Push Tags。我们可以选择推送所有标签还是当前分支标签。
data:image/s3,"s3://crabby-images/7d167/7d1673ce082e17552469e0d345026a282ed3e234" alt=""
代码拉取、推送
代码拉取项目右键 –> Git –> Repository –> pull
data:image/s3,"s3://crabby-images/eb9ab/eb9ab7e7939f828678f4a58be54bdf10f2863ef2" alt=""
代码推送项目右键 –> Git –> Repository –> push
data:image/s3,"s3://crabby-images/a59cf/a59cf49729eb04f85f455ea795a22dab801d29f3" alt=""
变基操作
普通变基
选择分支执行变基操作。这里需要注意当前分支为补丁分支,选中的分支为基底分支。也就是说当前分支提交会添加在选中分支提交之后。
data:image/s3,"s3://crabby-images/cd0ae/cd0ae046c6b1037a73f76e0e3707cda66aa3c2a4" alt=""
合并提交(交互式变基)
在代码没有pull前我们可以在本地分支进行提交的合并。这样会使得远程分支不去关心本地开发过程日志,而使得远程日志干净整洁。
变基前log
data:image/s3,"s3://crabby-images/fed1c/fed1c145eaf4edfa0e4c23a6ece3eeffe982689c" alt=""
找到要合并的第一条log,然后右键选择Interactively Rebase from Here…进行交互式变基
(此选项低版本IDEA可能没有请更新到2018版以上)
data:image/s3,"s3://crabby-images/de69e/de69e969df6ea995aa1c04f3c2b8c8d11437eba8" alt=""
除题一条外其他全部选择squash随前面的提交一并提交
data:image/s3,"s3://crabby-images/caed4/caed435465efbb27fbbc69165e3251a21e60673e" alt=""
编辑交互式变基提交说明。默认显示合并的所有提交的内容,我们也可以添加和修改内容。
data:image/s3,"s3://crabby-images/59ff6/59ff640f768b9d37ef644d190ac2549f6a7697f5" alt=""
变基后日志
data:image/s3,"s3://crabby-images/f66ed/f66ed4d35648bcd83a555b8ed8413a9129b0ea27" alt=""
查看提交日志
log页签
data:image/s3,"s3://crabby-images/fe0d5/fe0d55a2706d4969c7775d92d4566e2f93aea9b4" alt=""
查看控制台
console页签。在控制台中我们可以看到实际执行的git命令,可以帮助我们查找问题。
data:image/s3,"s3://crabby-images/0e601/0e6012b9279a813483cf7fd1c7cbf5bdbf665c01" alt=""
储藏工作区
有时我们需要经正在编写的代码临时储藏,然后去修改一些bug,完成bug修改后进行恢复。这时我们可以使用代码储藏。
项目右键 –> Git –> Repository –> Stash Changes
data:image/s3,"s3://crabby-images/f58a8/f58a808051d716797efb73bb9a0376652788bde2" alt=""
填写储藏名称
data:image/s3,"s3://crabby-images/7c22e/7c22e122957ccc39a44224cac94f8b1261be0ac6" alt=""
这是我们会发现修改的代码不见了。
之后我们要恢复储藏区的内容
项目右键 –> Git –> Repository –> UnStash Changes
data:image/s3,"s3://crabby-images/46a57/46a57c98b1a881e56a6ca3a521fcee239a80c09e" alt=""
选择要恢复的暂存名称并恢复暂存
data:image/s3,"s3://crabby-images/f1484/f148414d62434ee6e92bced035e182579e515e65" alt=""
这时我们发现修改的代码又回来了
提交回退
我们如果想要放弃最近一次提交的内容可以使用提交回退
回退前log
data:image/s3,"s3://crabby-images/e351f/e351f00dcdf6b69fefb2541b0843fb0948a7a52a" alt=""
项目右键 –> Git –> Repository –> Reset HEAD…
data:image/s3,"s3://crabby-images/3a84d/3a84d1987c3a5da0a439d7a303e89a5b3274a4ba" alt=""
执行回退(HEAD后面加几个^就回退几次提交)
data:image/s3,"s3://crabby-images/e450b/e450bad11dfb89be7fb2d8397507cfe6b245d862" alt=""
执行后日志
data:image/s3,"s3://crabby-images/e15dc/e15dc9cc17795e9ead576632db99859e6b8df5af" alt=""
管理远程仓库地址
项目右键 –> Git –> Repository –> Reotes…
data:image/s3,"s3://crabby-images/116d8/116d87d5023f4e2d276cfd11456d297cadc0d5d8" alt=""
data:image/s3,"s3://crabby-images/9df3a/9df3ae274deec77d1e953987fd6add662e8e7aed" alt=""
提交应用(挑樱桃)
我们可以使用提交应用的方式,将一次提交应用在其他分支上。
首先我们要切换至需要应用提交的分支上。
然后在log界面找到那次提交,右键 –> Cherry-Pick
data:image/s3,"s3://crabby-images/e5a5a/e5a5a26202120766baa51e54b2fc71aedf220be5" alt=""