管理自己的代码6——Git 子模块

一、引言

有种情况我们经常会遇到:某个工作中的项目需要包含并使用另一个项目。 也许是第三方库,或者你独立开发的,用于多个父项目的库。 现在问题来了:你想要把它们当做两个独立的项目,同时又想在一个项目中使用另一个,该如何操作呢?

Git 通过子模块来解决这个问题。 子模块允许你将一个 Git 仓库作为另一个 Git 仓库的子目录。 它能让你将另一个仓库克隆到自己的项目中,同时还保持提交的独立。

二、实例演示

1、登陆github,建立远程仓库。

2、填入相应的仓库参数,然后进行建立操作,本示例将建立StarrySkyLibrary,用于为StarrySky项目服务。

3、这是建立后的效果,大家可以通过网址:https://github.com/snmplink/snmplink-StarrySkyLibrary查看。

4、接下来,我们回到本地文件,通过Git Bash启动命令行窗口,先输入去除关联索引命令,命令后半部分是库存放的位置。这样当前Git就不再对Git进行代码控制了。

git rm -r --cached .//01_tutorial//01_turn_on_the_led//lib

5、下面,我们建立子模块,命令如下,建立之前应确保后半部分的文件目录不存在,如果有,可先做重名处理。

git submodule add https://github.com/snmplink/snmplink-StarrySkyLibrary .//01_tutorial//01_turn_on_the_led//lib

6、我们进行git状态查看,命令如下:

git status

7、可看到增加了.gitmodule文件,打开此文件内容如下,其标识了子模块的信息。如果有多个子模块,该文件中就会有多条记录。 要重点注意的是,该文件也像 .gitignore 文件一样受到(通过)版本控制。 它会和该项目的其他部分一同被拉取推送。 这就是克隆该项目的人知道去哪获得子模块的原因。

8、上述完成后,接下来,我们使用VS Code完成,会较为简单,我们打开VS Code,选择源代码管理器,可看到现在有2个版本保护。我们选择相应的版本,按照前述的内容进行管理就好了。

9、接下来我们将会克隆一个含有子模块的项目。 当你在克隆这样的项目时,默认会包含该子模块目录,但其中还没有任何文件。我们可以正确使用下列命令,进行代码克隆。

git clone --recursive https://github.com/snmplink/snmplink-StarrySkyLibrary

10、至此,我们就完成了git子模块的设置工作。

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

snmplink

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值