详解Eclipse提交项目到GitHub以及解决代码冲突
作者:逆天子陆离 时间:2022-05-15 09:04:52
前言:来这家公司上班后,开始使用Git作为项目版本控制系统,由于以前用的是SVN,所以对Git也就简单学习了一下。但是,实践出真知,当开始使用Git后,发现遇到了不少问题,也遇到过血的教训,于是决定记录一下,方便以后查看。
一、Eclipse安装Git插件
如果是比较新的Eclipse版本,默认就已经安装了Git插件。
菜单栏 --> Help
--> About Eclipse
,如下图:
如果有这个图标,表示Eclipse已经安装了Git插件,如果没有这个图标,就到Eclipse插件市场下载Git插件,具体步骤自行百度谷歌。
二、Eclipse提交代码到GitHub
1、登录GitHub,创建代码仓库
登录 github
,然后在右上角 +
号下拉列表里找到 New repository
,创建一个新的仓库。在 Repository name
填入 testgit
,其他保持默认设置,点击 Create repository
按钮,就成功地创建了一个空的Git仓库。
创建完成后如下图:
将最上方的仓库地址(也就是这个: https://github.com/你的GitHub账号名称/Git仓库名称.git
)复制下来,后面要用到。
2、在Eclipse中创建要发布到GitHub的项目
我这里是创建了一个最简单的Spring Boot项目,结构如下:
3、与GitHub建立连接,发布项目到GitHub
3.1 share project及创建本地Git仓库
选中要发布的项目 --> 右击 --> Team
--> Share Project...
,
勾选 Use or create repository in parent folder ofproject,
点击红色箭头处,也就是项目,
点击 Create Repository
按钮,会在后面显示的路径下建立本地仓库,最后点击Finish按钮即可。效果如下:
文件会变成未提交状态,此时我们可以提交代码到本地仓库。
3.2 提交代码到本地Git仓库
为了方便提交代码到Git,我们在Eclipse中打开相应的视图窗口,菜单栏 Window
--> Show View
--> Other...
,
在输入框中输入git,
选择 Git Staging
,确定即可。
选择项目,切换到 Git Staging
视图,
在未提交文件区选择要提交的文件,拖到下面待提交文件区或者右击选择的文件选择 Add to Index
,填写提交信息,点击Commit将文件提交到本地Git仓库。
3.3 发布项目到GitHub
选中要发布的项目 --> 右击 --> Team
--> Remote
--> Push...
,粘贴 URI
(也就是GitHub仓库地址, https://github.com/你的GitHub账号名称/Git仓库名称.git
),填写GitHub用户名 User
、密码 Password
,点击next。
点击 Source ref
的下拉框,选择 master [branch]
,然后点击 Add Spec
,下方 Specifications for push
下面会出现要提交的分支信息,点击Next,再点击Finish,最后点击OK就完成了。
最后在GitHub上查看项目。
三、Eclipse中使用Git
提交代码流程:一般是先 commit
到本地仓库,然后再 pull
更新远程仓库代码到本地,如果有冲突,文件会标红,解决冲突了再 commit
,最后 push
到远程仓库。
用血的教训得到的注意点:一定要经常 commit
代码到本地仓库!
当初就是因为没有提交代码到本地仓库,导致本地写的代码被远程仓库的代码覆盖了,周末加班重新写那些丢失的代码!
四、Eclipse中解决代码冲突
刚开始使用Git时,出现冲突后修改冲突部分,再提交到本地仓库,结果所有文件都冲突了,对比却又是一样的,当时不知道怎么办,就在另外的工作空间重新拉取一套代码,把修改的代码加进去。后来又遇到了,于是就找资料看怎么解决冲突,所以这里记录一下。
比如我现在的项目冲突情况如下:
现在我们解决冲突,比如改为下面这样:
右击冲突文件 --> Team
--> Add to Index
此时,冲突文件变为修改图标样式, Git Staging
视图中变成下图:
后面就是正常的提交代码流程了, commit
到本地仓库,再 push
到远程仓库。
来源:https://segmentfault.com/a/1190000018528906
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
Android 资源 id详解及的动态获取
Java中BigDecimal的加减乘除、比较大小与使用注意事项
![](https://img.aspxhome.com/file/2023/1/66251_0s.jpg)
Java Email邮件发送简单实现介绍
![](https://img.aspxhome.com/file/2023/8/62838_0s.png)
详解C#中使用对象或集合的初始值设定项初始化的操作
详解idea maven nexus 常见命令配置
![](https://img.aspxhome.com/file/2023/1/62731_0s.png)
java 动态生成bean的案例
使用Java和ffmpeg把音频和视频合成视频的操作方法
java 使用foreach遍历集合元素的实例
C#转换日期类型实例
Java网络编程之TCP通信完整代码示例
![](https://img.aspxhome.com/file/2023/2/71892_0s.gif)
springboot从application.properties中注入list, map方式
![](https://img.aspxhome.com/file/2023/9/60539_0s.jpg)
C# 设计模式系列教程-外观模式
![](https://img.aspxhome.com/file/2023/8/74818_0s.png)
Mybatis基于xml配置实现单表的增删改查功能
详解Java中多进程编程的实现
Java如何实现字符串每隔4位加空格
Java中notify和notifyAll的区别及何时使用
在IntelliJ IDEA中多线程并发代码的调试方法详解
![](https://img.aspxhome.com/file/2023/6/67146_0s.jpg)
详解Mybatis框架SQL防注入指南
![](https://img.aspxhome.com/file/2023/6/66046_0s.jpg)
Java 8 中的 10 个特性总结及详解
![](https://img.aspxhome.com/file/2023/0/65200_0s.png)
Zookeeper连接超时问题与拒绝连接的解决方案
![](https://img.aspxhome.com/file/2023/3/78863_0s.png)