关联本地Git客户端
首先要根据系统环境安装Git客户端
然后使用File --> Settings --> Version Control --> Git配置客户端安装目录
data:image/s3,"s3://crabby-images/88be6/88be65bef370f2068b60a06b30c1ac5efd3d31ba" alt=""
创建本地仓库
根据项目要求创建自己的项目
然后使用VCS --> Import into Version Control --> Create Git Repository...在项目上创建Git仓库
data:image/s3,"s3://crabby-images/2d339/2d339ebad4d5c6113a16f9134661267250d6e615" 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/8b0e1/8b0e1cc689ee2d65d1f45842ddc87d450ea52ec3" alt=""
提交代码
我们如果希望文件被Git管理那我们就要将文件进行add操作。
在IDEA中我们只要对某个文件设置一次add,之后就不用在手动进行add了。
文件右键 --> Git --> Add
data:image/s3,"s3://crabby-images/14f6c/14f6cc500e5c61f2f8cf8a50b072daab14ec01f7" alt=""
提交代码时我们使用 文件右键 --> Git --> Commit Directory...进行提交
data:image/s3,"s3://crabby-images/e1a5b/e1a5ba7d3264a76deabf78f8d4b00cb14bdb54ca" alt=""
分支管理
分支管理主要集中在IDEA的右下角操作区。
data:image/s3,"s3://crabby-images/686b2/686b2c993e80878b444a7312f07b5a11779c39f5" alt=""
主菜单功能
data:image/s3,"s3://crabby-images/fb514/fb514d67f496818a5b7f8f1bfdff79e9f3f60a46" alt=""
New Branch : 从当前分支新建分支。上图就是从master分支创建新的分支。
Checkout Tag or Revision : 使用分支、标签或提交编码,检出一个临时分支。
Local Branches : 本地分支列表。同时显示对应了那个远程分支。
Remote Branches : 远程分支列表。
本地分支菜单
data:image/s3,"s3://crabby-images/0a7d6/0a7d659661f7e42ac188d24b985410caa7c5df6e" alt=""
Checkout : 检出这个分支。
Checkout As... : 使用这个分支创建新的分支并检出到新分支。
Compare With... : 使用当前分支与所选分支做代码提交比较。
Rebase Current onto Selected: 在当前分支做变基。(将所选分支提交加入到当前分支)
Checkout with Rebase : 检出所选分支并做变基。(将当前分支提交加入到所选分支)
Merge into Current: 合并到当前分支(将所选分支合并到当前分支)
Rname:修改所选分支名称
Delete :删除所选分支
远程分支菜单
data:image/s3,"s3://crabby-images/fe209/fe209ba876f840f613a03b5d1e36c1db368b3308" alt=""
Checkout As... : 使用远程分支创建一个新的本地分支,并检出这个分支。
Compare With : 使用当前分支与所选分支做代码提交比较。
Rebase Current onto Selected : 在当前分支做变基。(将所选分支提交加入到当前分支)
Merge into Current: 合并分支(将当前分支与所选分支进行合并)
Delete :删除所选分支
本地分支推送到远程仓库
检出要推送的分支,然后项目右键 --> Git --> Repository --> push
data:image/s3,"s3://crabby-images/ffac3/ffac331850ce2b6c09e004380ba735dfb2c1fec2" alt=""
push的时候会有new标签提示会在远程新建分支
data:image/s3,"s3://crabby-images/f858f/f858f3f110eb4b78c004dda38318996415004c35" alt=""
标签管理
检出要打标签的分支,然后Git --> Repository --> Tag...
data:image/s3,"s3://crabby-images/94e10/94e1089f09db284dc8a12ea5cafa933b62e7e3c8" alt=""
本地标签推送到远程仓库
项目右键 --> Git --> Repository --> push
data:image/s3,"s3://crabby-images/e031e/e031e2d3ffac457fc11fe61c0730a03d913fcaf6" alt=""
然后选中底部的Push Tags。我们可以选择推送所有标签还是当前分支标签。
data:image/s3,"s3://crabby-images/3ae2f/3ae2f41c2eff192bd98d93d6f794cff51b0777e5" alt=""
代码拉取、推送
代码拉取项目右键 --> Git --> Repository --> pull
data:image/s3,"s3://crabby-images/3e85c/3e85c088784a01645aab379d95019563ac939aad" alt=""
代码推送项目右键 --> Git --> Repository --> push
data:image/s3,"s3://crabby-images/8c227/8c2273cc31c4e5cec8928499081c53e724e2c461" alt=""
变基操作
普通变基
选择分支执行变基操作。这里需要注意当前分支为补丁分支,选中的分支为基底分支。也就是说当前分支提交会添加在选中分支提交之后。
data:image/s3,"s3://crabby-images/40adf/40adf5bad7805b4daf6cb03659838a4ab00c5dd2" alt=""
合并提交(交互式变基)
在代码没有pull前我们可以在本地分支进行提交的合并。这样会使得远程分支不去关心本地开发过程日志,而使得远程日志干净整洁。
变基前log
data:image/s3,"s3://crabby-images/715da/715da4934c0ed9b5ef49ab789039880b5f28ee8b" alt=""
找到要合并的第一条log,然后右键选择Interactively Rebase from Here...进行交互式变基
(此选项低版本IDEA可能没有请更新到2018版以上)
data:image/s3,"s3://crabby-images/33501/33501fd5504dffa5bf65d896f24b7f3d341c6ba1" alt=""
除题一条外其他全部选择squash随前面的提交一并提交
data:image/s3,"s3://crabby-images/2147a/2147a7b1a052be4121362276bef40689f4144396" alt=""
编辑交互式变基提交说明。默认显示合并的所有提交的内容,我们也可以添加和修改内容。
data:image/s3,"s3://crabby-images/b2f0c/b2f0cb2b045157f61d834d0c075567eb90d9b45b" alt=""
变基后日志
data:image/s3,"s3://crabby-images/d35d8/d35d8529f8df18349c201fdf42b3e219f1516a52" alt=""
查看提交日志
log页签
data:image/s3,"s3://crabby-images/33a4a/33a4a152e2b371b8b1d662a0799ba6dd99049597" alt=""
查看控制台
console页签。在控制台中我们可以看到实际执行的git命令,可以帮助我们查找问题。
data:image/s3,"s3://crabby-images/a7d93/a7d9313f9a81a75d94bdea645ebc20b4dd16bda4" alt=""
储藏工作区
有时我们需要经正在编写的代码临时储藏,然后去修改一些bug,完成bug修改后进行恢复。这时我们可以使用代码储藏。
项目右键 --> Git --> Repository --> Stash Changes
data:image/s3,"s3://crabby-images/84c37/84c37e885aa4b239fe09f7f66f77b13cee196792" alt=""
填写储藏名称
data:image/s3,"s3://crabby-images/5681f/5681fc838e551bc29c12ac186874655b6591fa48" alt=""
这是我们会发现修改的代码不见了。
之后我们要恢复储藏区的内容
项目右键 --> Git --> Repository --> UnStash Changes
data:image/s3,"s3://crabby-images/ea0d7/ea0d75634d5497e5171bb73816c2936eb300dd2b" alt=""
选择要恢复的暂存名称并恢复暂存
data:image/s3,"s3://crabby-images/4129b/4129b4160fe6022275366d33daed1ee4514ec524" alt=""
这时我们发现修改的代码又回来了
提交回退
我们如果想要放弃最近一次提交的内容可以使用提交回退
回退前log
data:image/s3,"s3://crabby-images/d3caa/d3caa5618b26e509a842eb3ceec413dfbb173677" alt=""
项目右键 --> Git --> Repository --> Reset HEAD...
data:image/s3,"s3://crabby-images/ba077/ba077ddf507d648e2203d3e29eac4cd6ae2e110c" alt=""
执行回退(HEAD后面加几个^就回退几次提交)
data:image/s3,"s3://crabby-images/18ee8/18ee8170c65657028e48869710b95e832e959637" alt=""
执行后日志
data:image/s3,"s3://crabby-images/2463b/2463bbb605dd0a5577127a011d17f7d315b77975" alt=""
管理远程仓库地址
项目右键 --> Git --> Repository --> Reotes...
data:image/s3,"s3://crabby-images/a3d9a/a3d9a13b8df461398a0e6aefd73abccf0a304c6f" alt=""
data:image/s3,"s3://crabby-images/0ed9f/0ed9febe656e52de026afbd3ff1160e59f0b9df4" alt=""
提交应用(挑樱桃)
我们可以使用提交应用的方式,将一次提交应用在其他分支上。
首先我们要切换至需要应用提交的分支上。
然后在log界面找到那次提交,右键 --> Cherry-Pick
data:image/s3,"s3://crabby-images/99099/99099dbef56f1d9f9ced7972e8f4d1e979a510ca" alt=""
网友评论