侧边栏壁纸
博主头像
落叶人生博主等级

走进秋风,寻找秋天的落叶

  • 累计撰写 130557 篇文章
  • 累计创建 28 个标签
  • 累计收到 9 条评论
标签搜索

目 录CONTENT

文章目录

git 入门教程之里程碑式标签

2023-12-14 星期四 / 0 评论 / 0 点赞 / 12 阅读 / 3242 字

"春风得意马蹄疾,一日看尽长安花",对于项目也是如此,最值得期待的恐怕就要数新版本发布的时刻了吧?每当发布新版本时要么是版本号命名(比如v0.0.1)或者代号命名(比如Chelsea),不管怎么说这种

"春风得意马蹄疾,一日看尽长安花",对于项目也是如此,最值得期待的恐怕就要数新版本发布的时刻了吧?每当发布新版本时要么是版本号命名(比如v0.0.1)或者代号命名(比如Chelsea),不管怎么说这种里程碑阶段总是要留下些许纪念意义.

既然想要纪念这种特殊的历史时刻,自然是希望它能够固定下来,不要发生随意移动,产生不可预期后果.

这种需求其实和我们前面说的分支概念很相似,均是源于特殊的版本号,逐渐收集起一系列版本,最终形成一条相对独立的历史线,但分支并不是实现里程碑概念的最佳选择,为什么?

分支适合多人协作开发时互不影响,适当时机主动合并他人工作成果这种模式,而这种模式是由不同的功能模块进行驱动的,正所谓"天下大势分久必合,合久必分",当功能模块开发完毕后自然也就没有分支存在的必要性,更何况分支在收集版本的过程中会一直移动,并没有特殊的固定版本,显然分支不是最佳选择!

但是,分支确定一定程度上和里程碑概念很相似,源于特定版本,自主命名,收集版本等,那么何必重头再来,为何不复用已有概念呢?

实际上,git 中的标签(tag) 就是实现里程碑概念的方式,它可以永久性指向特定的提交并将命名,然后就可以将其理解成分支一样引用了!

但标签(tag)不是分支(branch),标签是一个点的话,分支就是若干点连接而成的线,标签是静态的,分支是动态的,标签是只读的,分只是可读可写的.

创建标签 git tag <tag>

# 方式一: 默认 `HEAD` 指向的版本git tag v0.0.1# 方式二: 指定 `commit_id` 表示的版本git tag v0.0.2 f971647# 方式三: 指定 `commit_id` 表示的版本,同时创建标签说明信息git tag -a v0.0.3 -m "v0.0.3" f971647

列出标签 git tag

git tag 

显示标签 git show <tag>

git show v0.0.1

删除标签 git tag -d <tag>

git tag -d v0.0.1

推送标签 git push origin <tag>

git push origin v0.0.1

推送全部标签 git push origin --tags

git push origin --tags

删除远程标签 git tag -d <tag> git push origin :refs/tags/<tag>

# 删除本地标签 git tag -d v0.0.1# 推送删除标签(删除也是推送)git push origin :refs/tags/v0.0.1

广告 广告

评论区