一步一步教你学会使用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中各种常见文件的读写操作与类型转换详细指南

《python中各种常见文件的读写操作与类型转换详细指南》这篇文章主要为大家详细介绍了python中各种常见文件(txt,xls,csv,sql,二进制文件)的读写操作与类型转换,感兴趣的小伙伴可以跟... 目录1.文件txt读写标准用法1.1写入文件1.2读取文件2. 二进制文件读取3. 大文件读取3.1

Java使用SLF4J记录不同级别日志的示例详解

《Java使用SLF4J记录不同级别日志的示例详解》SLF4J是一个简单的日志门面,它允许在运行时选择不同的日志实现,这篇文章主要为大家详细介绍了如何使用SLF4J记录不同级别日志,感兴趣的可以了解下... 目录一、SLF4J简介二、添加依赖三、配置Logback四、记录不同级别的日志五、总结一、SLF4J

使用Python实现一个优雅的异步定时器

《使用Python实现一个优雅的异步定时器》在Python中实现定时器功能是一个常见需求,尤其是在需要周期性执行任务的场景下,本文给大家介绍了基于asyncio和threading模块,可扩展的异步定... 目录需求背景代码1. 单例事件循环的实现2. 事件循环的运行与关闭3. 定时器核心逻辑4. 启动与停

如何使用Nginx配置将80端口重定向到443端口

《如何使用Nginx配置将80端口重定向到443端口》这篇文章主要为大家详细介绍了如何将Nginx配置为将HTTP(80端口)请求重定向到HTTPS(443端口),文中的示例代码讲解详细,有需要的小伙... 目录1. 创建或编辑Nginx配置文件2. 配置HTTP重定向到HTTPS3. 配置HTTPS服务器

Java使用ANTLR4对Lua脚本语法校验详解

《Java使用ANTLR4对Lua脚本语法校验详解》ANTLR是一个强大的解析器生成器,用于读取、处理、执行或翻译结构化文本或二进制文件,下面就跟随小编一起看看Java如何使用ANTLR4对Lua脚本... 目录什么是ANTLR?第一个例子ANTLR4 的工作流程Lua脚本语法校验准备一个Lua Gramm

Java Optional的使用技巧与最佳实践

《JavaOptional的使用技巧与最佳实践》在Java中,Optional是用于优雅处理null的容器类,其核心目标是显式提醒开发者处理空值场景,避免NullPointerExce... 目录一、Optional 的核心用途二、使用技巧与最佳实践三、常见误区与反模式四、替代方案与扩展五、总结在 Java

Linux内核参数配置与验证详细指南

《Linux内核参数配置与验证详细指南》在Linux系统运维和性能优化中,内核参数(sysctl)的配置至关重要,本文主要来聊聊如何配置与验证这些Linux内核参数,希望对大家有一定的帮助... 目录1. 引言2. 内核参数的作用3. 如何设置内核参数3.1 临时设置(重启失效)3.2 永久设置(重启仍生效

使用Java将DOCX文档解析为Markdown文档的代码实现

《使用Java将DOCX文档解析为Markdown文档的代码实现》在现代文档处理中,Markdown(MD)因其简洁的语法和良好的可读性,逐渐成为开发者、技术写作者和内容创作者的首选格式,然而,许多文... 目录引言1. 工具和库介绍2. 安装依赖库3. 使用Apache POI解析DOCX文档4. 将解析

Qt中QUndoView控件的具体使用

《Qt中QUndoView控件的具体使用》QUndoView是Qt框架中用于可视化显示QUndoStack内容的控件,本文主要介绍了Qt中QUndoView控件的具体使用,具有一定的参考价值,感兴趣的... 目录引言一、QUndoView 的用途二、工作原理三、 如何与 QUnDOStack 配合使用四、自

C++使用printf语句实现进制转换的示例代码

《C++使用printf语句实现进制转换的示例代码》在C语言中,printf函数可以直接实现部分进制转换功能,通过格式说明符(formatspecifier)快速输出不同进制的数值,下面给大家分享C+... 目录一、printf 原生支持的进制转换1. 十进制、八进制、十六进制转换2. 显示进制前缀3. 指