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

相关文章

线上Java OOM问题定位与解决方案超详细解析

《线上JavaOOM问题定位与解决方案超详细解析》OOM是JVM抛出的错误,表示内存分配失败,:本文主要介绍线上JavaOOM问题定位与解决方案的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一、OOM问题核心认知1.1 OOM定义与技术定位1.2 OOM常见类型及技术特征二、OOM问题定位工具

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建

Python使用FastAPI实现大文件分片上传与断点续传功能

《Python使用FastAPI实现大文件分片上传与断点续传功能》大文件直传常遇到超时、网络抖动失败、失败后只能重传的问题,分片上传+断点续传可以把大文件拆成若干小块逐个上传,并在中断后从已完成分片继... 目录一、接口设计二、服务端实现(FastAPI)2.1 运行环境2.2 目录结构建议2.3 serv

Spring Security简介、使用与最佳实践

《SpringSecurity简介、使用与最佳实践》SpringSecurity是一个能够为基于Spring的企业应用系统提供声明式的安全访问控制解决方案的安全框架,本文给大家介绍SpringSec... 目录一、如何理解 Spring Security?—— 核心思想二、如何在 Java 项目中使用?——

springboot中使用okhttp3的小结

《springboot中使用okhttp3的小结》OkHttp3是一个JavaHTTP客户端,可以处理各种请求类型,比如GET、POST、PUT等,并且支持高效的HTTP连接池、请求和响应缓存、以及异... 在 Spring Boot 项目中使用 OkHttp3 进行 HTTP 请求是一个高效且流行的方式。

Java使用Javassist动态生成HelloWorld类

《Java使用Javassist动态生成HelloWorld类》Javassist是一个非常强大的字节码操作和定义库,它允许开发者在运行时创建新的类或者修改现有的类,本文将简单介绍如何使用Javass... 目录1. Javassist简介2. 环境准备3. 动态生成HelloWorld类3.1 创建CtC

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Java使用jar命令配置服务器端口的完整指南

《Java使用jar命令配置服务器端口的完整指南》本文将详细介绍如何使用java-jar命令启动应用,并重点讲解如何配置服务器端口,同时提供一个实用的Web工具来简化这一过程,希望对大家有所帮助... 目录1. Java Jar文件简介1.1 什么是Jar文件1.2 创建可执行Jar文件2. 使用java

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

Java中的抽象类与abstract 关键字使用详解

《Java中的抽象类与abstract关键字使用详解》:本文主要介绍Java中的抽象类与abstract关键字使用详解,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、抽象类的概念二、使用 abstract2.1 修饰类 => 抽象类2.2 修饰方法 => 抽象方法,没有