日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Git复习(六)之标签管理

發布時間:2025/3/15 编程问答 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Git复习(六)之标签管理 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

標簽管理

發布一個版本時,我們通常先在版本庫中打一個標簽(tag),這樣,就唯一確定了打標簽時刻的版本。將來無論什么時候,取某個標簽的版本,就是把那個打標簽的時刻的歷史版本取出來。所以,標簽也是版本庫的一個快照。

Git的標簽雖然是版本庫的快照,但其實它就是指向某個commit的指針(跟分支很像對不對?但是分支可以移動,標簽不能移動),所以,創建和刪除標簽都是瞬間完成的。

Git有commit,為什么還要引入tag?

“請把上周一的那個版本打包發布,commit號是6a5819e...”

“一串亂七八糟的數字不好找!”

如果換一個辦法:

“請把上周一的那個版本打包發布,版本號是v1.2”

“好的,按照tag v1.2查找commit就行!”

所以,tag就是一個讓人容易記住的有意義的名字,它跟某個commit綁在一起

創建標簽

在Git中打標簽非常簡單,首先,切換到需要打標簽的分支上:

$ git branch * devmaster $ git checkout master Switched to branch 'master'

然后,敲命令git tag <name>就可以打一個新標簽:

$ git tag v1.0

可以用命令git tag查看所有標簽:

$ git tag v1.0

默認標簽是打在最新提交的commit上的。有時候,如果忘了打標簽,比如,現在已經是周五了,但應該在周一打的標簽沒有打,怎么辦?

方法是找到歷史提交的commit id,然后打上就可以了:

$ git log --pretty=oneline --abbrev-commit 12a631b (HEAD -> master, tag: v1.0, origin/master) merged bug fix 101 4c805e2 fix bug 101 e1e9c68 merge with no-ff f52c633 add merge cf810e4 conflict fixed 5dc6824 & simple 14096d0 AND simple b17d20e branch test d46f35e remove test.txt b84166e add test.txt 519219b git tracks changes e43a48b understand how stage works 1094adb append GPL e475afc add distributed eaadf4e wrote a readme file

比方說要對add merge這次提交打標簽,它對應的commit id是f52c633,敲入命令:

$ git tag v0.9 f52c633

再用命令git tag查看標簽:

$ git tag v0.9 v1.0

注意,標簽不是按時間順序列出,而是按字母排序的。可以用git show <tagname>查看標簽信息:

$ git show v0.9 commit f52c63349bc3c1593499807e5c8e972b82c8f286 (tag: v0.9) Author: Michael Liao <askxuefeng@gmail.com> Date: Fri May 18 21:56:54 2018 +0800add mergediff --git a/readme.txt b/readme.txt ...

可以看到,v0.9確實打在add merge這次提交上。

還可以創建帶有說明的標簽,用-a指定標簽名,-m指定說明文字:

$ git tag -a v0.1 -m "version 0.1 released" 1094adb

用命令git show <tagname>可以看到說明文字:

$ git show v0.1 tag v0.1 Tagger: Michael Liao <askxuefeng@gmail.com> Date: Fri May 18 22:48:43 2018 +0800version 0.1 releasedcommit 1094adb7b9b3807259d8cb349e7df1d4d6477073 (tag: v0.1) Author: Michael Liao <askxuefeng@gmail.com> Date: Fri May 18 21:06:15 2018 +0800append GPLdiff --git a/readme.txt b/readme.txt ...

???注意:標簽總是和某個commit掛鉤。如果這個commit既出現在master分支,又出現在dev分支,那么在這兩個分支上都可以看到這個標簽。

操作標簽

如果標簽打錯了,也可以刪除:

$ git tag -d v0.1 Deleted tag 'v0.1' (was f15b0dd)

因為創建的標簽都只存儲在本地,不會自動推送到遠程。所以,打錯的標簽可以在本地安全刪除。

如果要推送某個標簽到遠程,使用命令git push origin <tagname>

$ git push origin v1.0 Total 0 (delta 0), reused 0 (delta 0) To github.com:michaelliao/learngit.git* [new tag] v1.0 -> v1.0

或者,一次性推送全部尚未推送到遠程的本地標簽:

$ git push origin --tags Total 0 (delta 0), reused 0 (delta 0) To github.com:michaelliao/learngit.git* [new tag] v0.9 -> v0.9

如果標簽已經推送到遠程,要刪除遠程標簽就麻煩一點,先從本地刪除:

$ git tag -d v0.9 Deleted tag 'v0.9' (was f52c633)

然后,從遠程刪除。刪除命令也是push,但是格式如下:

$ git push origin :refs/tags/v0.9 To github.com:michaelliao/learngit.git- [deleted] v0.9

要看看是否真的從遠程庫刪除了標簽,可以登陸GitHub查看。?

轉載于:https://www.cnblogs.com/kunmomo/p/11364310.html

與50位技術專家面對面20年技術見證,附贈技術全景圖

總結

以上是生活随笔為你收集整理的Git复习(六)之标签管理的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。