一步一步教你学会使用git 第三集 (超详细,图文)

2024-03-15 17:32

本文主要是介绍一步一步教你学会使用git 第三集 (超详细,图文),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  1. 在实际开发过程当中有可能会出现在原先代码的基础上又有不同的需求,而这两种不同的需求要同时开发。这时就需要分支管理。
  2. 在git当中所有的版本都会延续一条主线,这个主线叫做master主分支。就好比你看一场电影,它的故事情节就是一条主线。此时它的结构应该是这样的,如下图:
  3. 在git当中有个HEAD(头)它指向master分支的最新节点,如下图:
  4. 此时我们可以在主线上创建一个分支,让HEAD指向分支,如下图所示:
  5. 在git当中可以使用 git  branch develop创建分支;可以使用 git checkout develop切换分支;使用git checkout -b develop创建并切换分支;使用git branch查看分支
  6. 我们使用git branch命令查看一下分支,如下图:

    我们看到当前只有主master分支
  7. 我们使用git branch develop创建分支,然后再使用git branch命令查看分支情况,发现新增了一个分支,如下图所示:

    此时可以看到master是绿色的,表示它依然是目前占用的主分支,注意它前面还有个星号。
  8. 此时我们使用git checkout develop命令来切换分支,然后再使用git branch查看分支的情况,如下图:

    我们看到develop变成了绿色,并且前面有个星号。表示当前正在占用的分支是develop。这样我们就实现了下图的效果:
  9. 接下来我们做一个实验,看看不同的分支对项目的进程是如何控制的。首先我们还是将分支切换回master,如下图:
  10. 切换到master后我们修改一下HelloWorld.java文件,增加一条输出语句,如下图:

    增加了一条输出语句System.out.println("在master分支下输出一条信息");
  11. 接下来我们添加并提交,如下图所示:
  12. 我们使用git checkout develop切换到develop分支,并使用git branch查看分支如下图:

    此时再去查看HelloWorld.java文件,发现新添加的一行输出不见了,如下图:
  13. 我们再使用git checkout master切换回去,再看HelloWorld.java发现那消失的一行语句又回来了。如下图:
  14. 我们再次切换回develop分支,然后在该分支下也添加一条输出语句,如下图:


  15. 此时再次切换到master分之下查看HelloWorld.java文件发现内容又变回master分支的内容了,如下图:

  16. 我们可以在master分支的基础上继续创建新的分支,git branch newDev,并且让HEAD指向newDev分支。现在的分支结构如下图:


    我们此时可以在最新的分支下工作。
  17. 当然我们也可以删除分支。我们使用git branch -d newDev删除分支,发现提示删除失败,原因是该分支正在使用中,如下图所示:
  18. 我们可以先使用git checkout命令切换一下分支,然后再删除该分支,如下图:

    我们发现newDev这个分支已经被删除了,同时master分支被HEAD指针选中。那么这个时候的git分支情况如下图:
  19. 在开发的最后阶段,我们可能需要将不同的分支合并。那么合并的结果就有可能会产生冲突。因为我们的master分支和devlop分支都对HelloWorld.java文件进行了修改。
  20. 使用git merge develop命令合并分支,此时会报错。告诉你文件已经产生了冲突。如下图:

    打开HelloWorld.java文件内容如下:
  21. 此时我们需要编辑冲突,编辑冲突的方式也很简单,就是把想留下来的部分保留。把不需要的部分去掉就可以了。我们看到<<<<<<<< ==========和>>>>>>>>>>>这些符号是我们不要的,而两条输出语句我们都想保留。因此把不需要的符号去掉即可,如下图:
  22. 此时我们再次执行git status,发现有个文件没有提交。那么我们git addgit commit提交即可,如下图:
  23. 我们这时候再使用git branch命令查看一下分支情况,发现master分支仍然是当前分支。如下图:
  24. 那么我们这时候再次切换到develop分支呢?情况如何?

    这时候我们再看HelloWorld.java文件,发现它里面的内容又是develop分支当中的内容了,如下图:

    也就是说刚才的合并分支是将master当中的内容与develop分支当中的内容合并到了master分支上了,而develop分支没有被改变。develop分支依然存在。如果不再需要develop分支,我们可以使用git branch -d develop命令删除develop分支。
  25. 我们也可以使用git log --graph --pretty=oneline --abbrev-commit命令查看日志信息,如下图所示:
  26. 我们可以使用git push origin本地分支名:远程分支名将分支push到远程仓库,如果没有冒号那么本地分支名将会与远程分支名相同,如下图:

    发现这里已经有两个分支了,然后点开可以看见具体的分支详情,如下图:
  27. 此时输入$ git push origin master将master分支也提交到远程仓库,如下图:

  28. github是可以开源协同开发一个项目的,这就带来一个问题。某一天你想参与一个强大团队的开源项目开发。但是这个团队的老大不一定认可你。怕你随意修改他的代码会对他的团队带来损失。因此你可以fork他的项目到你自己的项目库,经过修改后再pull request(拉取请求)到大牛团队里,如果大牛团队认可了你就会接受你的pull request,这样你们就可以协同一起开发项目了。
  29. github上有个测试fork的项目,项目网址是:https://github.com/octocat/Spoon-Knife/,我们打开这个网址看到如下内容:
  30. 点击Fork按钮此时会进入如下界面:
  31. 稍后会在你的仓库当中创建Spoon-Knife项目,如下图:
  32. 项目已经到了我们自己的仓库当中,我们就可以随意修改了。比如下载项目,修改然后再上传,如下图:
  33. 此时我们可以点击New pull request按钮向大牛团队发起拉取请求,如下图:
  34. 这个时候回到了大牛团队项目库,可以看见你发送了一个pull request,如下图:

    我们看到已经有很多人向该团队发送pull请求了。项目方是否接受你的请求则视情况而定。
  35. 当你觉得你的github仓库当中的项目已经没有存在的必要了,那么可以删除你的项目。方法是在项目主界面当中点击Settings按钮,如下图:
  36. 进入设置界面后向下拉,找到Danger Zone,点击最下面的Delete this repository按钮如下图:
  37. 此时会提示你这个操作不可逆,你必须输入项目名称以确认才能删除,如下图:
  38. 点击红色按钮后即可删除

    上一篇:一步一步教你 学会使用git 第二集 (超详细,图文) 

这篇关于一步一步教你学会使用git 第三集 (超详细,图文)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/812716

相关文章

DeepSeek模型本地部署的详细教程

《DeepSeek模型本地部署的详细教程》DeepSeek作为一款开源且性能强大的大语言模型,提供了灵活的本地部署方案,让用户能够在本地环境中高效运行模型,同时保护数据隐私,在本地成功部署DeepSe... 目录一、环境准备(一)硬件需求(二)软件依赖二、安装Ollama三、下载并部署DeepSeek模型选

Java function函数式接口的使用方法与实例

《Javafunction函数式接口的使用方法与实例》:本文主要介绍Javafunction函数式接口的使用方法与实例,函数式接口如一支未完成的诗篇,用Lambda表达式作韵脚,将代码的机械美感... 目录引言-当代码遇见诗性一、函数式接口的生物学解构1.1 函数式接口的基因密码1.2 六大核心接口的形态学

使用DeepSeek API 结合VSCode提升开发效率

《使用DeepSeekAPI结合VSCode提升开发效率》:本文主要介绍DeepSeekAPI与VisualStudioCode(VSCode)结合使用,以提升软件开发效率,具有一定的参考价值... 目录引言准备工作安装必要的 VSCode 扩展配置 DeepSeek API1. 创建 API 请求文件2.

电脑密码怎么设置? 一文读懂电脑密码的详细指南

《电脑密码怎么设置?一文读懂电脑密码的详细指南》为了保护个人隐私和数据安全,设置电脑密码显得尤为重要,那么,如何在电脑上设置密码呢?详细请看下文介绍... 设置电脑密码是保护个人隐私、数据安全以及系统安全的重要措施,下面以Windows 11系统为例,跟大家分享一下设置电脑密码的具体办php法。Windo

使用TomCat,service输出台出现乱码的解决

《使用TomCat,service输出台出现乱码的解决》本文介绍了解决Tomcat服务输出台中文乱码问题的两种方法,第一种方法是修改`logging.properties`文件中的`prefix`和`... 目录使用TomCat,service输出台出现乱码问题1解决方案问题2解决方案总结使用TomCat,

解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题

《解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题》文章详细描述了在使用lombok的@Data注解标注实体类时遇到编译无误但运行时报错的问题,分析... 目录问题分析问题解决方案步骤一步骤二步骤三总结问题使用lombok注解@Data标注实体类,编译时

JSON字符串转成java的Map对象详细步骤

《JSON字符串转成java的Map对象详细步骤》:本文主要介绍如何将JSON字符串转换为Java对象的步骤,包括定义Element类、使用Jackson库解析JSON和添加依赖,文中通过代码介绍... 目录步骤 1: 定义 Element 类步骤 2: 使用 Jackson 库解析 jsON步骤 3: 添

VScode连接远程Linux服务器环境配置图文教程

《VScode连接远程Linux服务器环境配置图文教程》:本文主要介绍如何安装和配置VSCode,包括安装步骤、环境配置(如汉化包、远程SSH连接)、语言包安装(如C/C++插件)等,文中给出了详... 目录一、安装vscode二、环境配置1.中文汉化包2.安装remote-ssh,用于远程连接2.1安装2

vscode保存代码时自动eslint格式化图文教程

《vscode保存代码时自动eslint格式化图文教程》:本文主要介绍vscode保存代码时自动eslint格式化的相关资料,包括打开设置文件并复制特定内容,文中通过代码介绍的非常详细,需要的朋友... 目录1、点击设置2、选择远程--->点击右上角打开设置3、会弹出settings.json文件,将以下内

将sqlserver数据迁移到mysql的详细步骤记录

《将sqlserver数据迁移到mysql的详细步骤记录》:本文主要介绍将SQLServer数据迁移到MySQL的步骤,包括导出数据、转换数据格式和导入数据,通过示例和工具说明,帮助大家顺利完成... 目录前言一、导出SQL Server 数据二、转换数据格式为mysql兼容格式三、导入数据到MySQL数据