一步一步教你学会使用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

相关文章

Python数据验证神器Pydantic库的使用和实践中的避坑指南

《Python数据验证神器Pydantic库的使用和实践中的避坑指南》Pydantic是一个用于数据验证和设置的库,可以显著简化API接口开发,文章通过一个实际案例,展示了Pydantic如何在生产环... 目录1️⃣ 崩溃时刻:当你的API接口又双叒崩了!2️⃣ 神兵天降:3行代码解决验证难题3️⃣ 深度

Linux内核定时器使用及说明

《Linux内核定时器使用及说明》文章详细介绍了Linux内核定时器的特性、核心数据结构、时间相关转换函数以及操作API,通过示例展示了如何编写和使用定时器,包括按键消抖的应用... 目录1.linux内核定时器特征2.Linux内核定时器核心数据结构3.Linux内核时间相关转换函数4.Linux内核定时

python中的flask_sqlalchemy的使用及示例详解

《python中的flask_sqlalchemy的使用及示例详解》文章主要介绍了在使用SQLAlchemy创建模型实例时,通过元类动态创建实例的方式,并说明了如何在实例化时执行__init__方法,... 目录@orm.reconstructorSQLAlchemy的回滚关联其他模型数据库基本操作将数据添

Spring配置扩展之JavaConfig的使用小结

《Spring配置扩展之JavaConfig的使用小结》JavaConfig是Spring框架中基于纯Java代码的配置方式,用于替代传统的XML配置,通过注解(如@Bean)定义Spring容器的组... 目录JavaConfig 的概念什么是JavaConfig?为什么使用 JavaConfig?Jav

Java使用Spire.Doc for Java实现Word自动化插入图片

《Java使用Spire.DocforJava实现Word自动化插入图片》在日常工作中,Word文档是不可或缺的工具,而图片作为信息传达的重要载体,其在文档中的插入与布局显得尤为关键,下面我们就来... 目录1. Spire.Doc for Java库介绍与安装2. 使用特定的环绕方式插入图片3. 在指定位

Springboot3 ResponseEntity 完全使用案例

《Springboot3ResponseEntity完全使用案例》ResponseEntity是SpringBoot中控制HTTP响应的核心工具——它能让你精准定义响应状态码、响应头、响应体,相比... 目录Spring Boot 3 ResponseEntity 完全使用教程前置准备1. 项目基础依赖(M

Java使用Spire.Barcode for Java实现条形码生成与识别

《Java使用Spire.BarcodeforJava实现条形码生成与识别》在现代商业和技术领域,条形码无处不在,本教程将引导您深入了解如何在您的Java项目中利用Spire.Barcodefor... 目录1. Spire.Barcode for Java 简介与环境配置2. 使用 Spire.Barco

SQL Server中行转列方法详细讲解

《SQLServer中行转列方法详细讲解》SQL行转列、列转行可以帮助我们更方便地处理数据,生成需要的报表和结果集,:本文主要介绍SQLServer中行转列方法的相关资料,需要的朋友可以参考下... 目录前言一、为什么需要行转列二、行转列的基本概念三、使用PIVOT运算符进行行转列1.创建示例数据表并插入数

Android使用java实现网络连通性检查详解

《Android使用java实现网络连通性检查详解》这篇文章主要为大家详细介绍了Android使用java实现网络连通性检查的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录NetCheck.Java(可直接拷贝)使用示例(Activity/Fragment 内)权限要求

C# 预处理指令(# 指令)的具体使用

《C#预处理指令(#指令)的具体使用》本文主要介绍了C#预处理指令(#指令)的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录1、预处理指令的本质2、条件编译指令2.1 #define 和 #undef2.2 #if, #el