当前位置:首页 > 技术分析 > 正文内容

Git Submodule子模块功能,你使用过吗?

ruisui883个月前 (02-16)技术分析14

子模块

在项目开发中,经常会遇到这种情况:某个工作项目中包含另一个项目,或者是第三方库,或者独立开发时,用多个父项目的库。问题来了:想把他们当成两个独立的项目,又想在一个项目中使用另外一个,该如何解决呢?

答案很简单,那就是使用Git的子模块功能。子模块允许将一个git仓库作为另一个仓库的子目录,能让你将一个仓库clone到自己项目中,同时还保持独立的提交。

Git

使用子模块

将一个已存在的仓库添加为正在工作的项目的子目录。

添加submodule

默认情况下,子模块将会放到一个与仓库同名的目录中。此时运行git status,会发现有几个新增的文件。首先是.gitmodules文件,该文件中包含了文件保存的URL与本地目录之间的映射。

我们可以查看下.gitmodules文件内容。

.gitmodule文件内容

clone含有子模块的项目

在clone主项目的过程中,默认会包含子模块的项目,但其中没有任何文件。

clone带有子模块的项目

进入到DbConnector目录,该目录是空的。必须运行下面两个命令:

检出子模块

或者使用--recrusive选项,会自动初始化并更新每一个子模块。

自动更新子模块

包含子模块的项目上工作

子模块和主项目可以独立进行开发,但是子模块和主项目上的工作需要单独提交,在子模块提交后,即使主项目未有任何修改,在主项目中也会有记录,因此主项目也要commit一次,主项目是通过commit id与子模块保持代码一致的。

在子项目开发完后,进行提交。

子项目commit

然后切换到主项目目录下,进行提交。

主项目commit

总结

今天这篇文章主要讲的是Git子模块的知识,如果你也做过涉及子模块的项目,应该会对这篇文章有感触吧。

扫描二维码推送至手机访问。

版权声明:本文由ruisui88发布,如需转载请注明出处。

本文链接:http://www.ruisui88.com/post/1971.html

标签: gitsubmodule
分享给朋友:

“Git Submodule子模块功能,你使用过吗?” 的相关文章

Vue组件通信之props深入详解!

props 是 Vue 组件中一个很重要的概念。它是用来从父组件向子组件传递数据的。为什么需要props?这是因为在Vue中,组件是相互隔离的。每个组件都有自己的作用域,子组件无法直接访问父组件的状态或值。通过props,父组件可以将数据传递给子组件。使用props的步骤:1. 在子组件中定义pro...

gitlab常用命令大全

GitLab常用命令大全GitLab是一个基于Git的Web平台,它不仅提供代码托管,还集成了持续集成/持续交付(CI/CD)、代码审查、问题追踪等功能。在日常使用GitLab的过程中,我们常常需要使用一系列命令来管理代码仓库、处理分支和标签等。以下是GitLab常用的Git命令大全,并附上详细解释...

java调用API操作GitLab

最近需要在一个WEB项目中集成GitLab,用到了GitLab的API操作,在网上找了很久都是说直接调用GitLab的Http接口,而且API官方只有javadoc没有其它说明文档,特别记录下,以备查询。这里采用Token的认证方式,因此需要先登陆GitLab新建一个Token,创建方式如下:创建完...

虚幻引擎5.5现已发布 手游开发、动画制作重大改进

Epic在今天发布了虚幻引擎5.5,现可通过Epic Launcher下载。此版本在动画创作、渲染、虚拟制片、移动端游戏开发和开发人员迭代工具集等方面做出了重大改进。 官方博客:虚幻引擎5.5现已发布,在动画创作、虚拟制作和移动游戏开发方面取得了显著进步,渲染、摄像机内视觉特效和开发人员迭代等领域的...

Vue2的16种传参通信方式

前言先直入主题列出有哪些传参方式,下面再通过事例一一讲解。props(父传子)$emit与v-on (子传父)EventBus (兄弟传参).sync与update: (父子双向)v-model (父子双向)ref$children与$parent$attrs与$listeners (爷孙双向)pr...

Vue真是太好了 壹万多字的Vue知识点 超详细!

1??、Vue和其他两大框架的区别Angular 学习成本太高React 代码可读性差Vue 学习成本较低 很容易上手VUE官方: https://cn.vuejs.org/v2/guide/comparison.html?2??、Vue是什么Vue是一套用于构建用户界面的渐进式框架 "前端...