golang flag包的使用教程
前言
說起 golang 的 flag 個(gè)包,我們第一反應(yīng)的是什么呢?至少我曾經(jīng)第一次看到 flag 包的時(shí)候,第一反應(yīng)是想起寫 C 語言的時(shí)候咱們用于定義一個(gè)表示的,我們一般會(huì)命名為 flag 變量
實(shí)際上 golang 的 flag 包是用于處理命令行參數(shù)的工具包,我們可以基于這個(gè)包來開發(fā)自定義的命令行工具
對于命令行,相信大家都不陌生吧,學(xué)過 C 的就知道,如下代碼是否很熟悉
int?main(int?argc,char?**argv) { ????//?打印?agrc??和?argv ????????return?0; }
其中 argc 表示命令行的參數(shù)個(gè)數(shù), argv 二級(jí)指針表示實(shí)際的命令參數(shù)
那么,對于咱們的 golang 是如何玩的,咱們先寫個(gè) demo 看看效果
main.go
func?main()?{ ???if?len(os.Args)?>?0?{ ??????fmt.Println("len(os.Args)?==?",?len(os.Args)) ??????for?_,?v?:=?range?os.Args?{ ?????????fmt.Println(v) ??????} ???} }
效果如下:
咱們 go build 輸出程序名為 testFlag 的可執(zhí)行程序,如下運(yùn)行即可
當(dāng)然需要看非常詳細(xì)和全面的關(guān)于 flag 包的內(nèi)容,可以直接查看官方文檔 ,此處咱們是對 flag 包的介紹,平常都會(huì)使用到的一些功能,以及注意事項(xiàng),分別從如下 3 個(gè)小點(diǎn)介紹一下常用的功能
- 注冊 flag 和 Flag 解析支持的數(shù)據(jù)類型
- 綁定 flag 變量
- flag.Parse() 的使用方式
注冊 flag 和 Flag 解析支持的數(shù)據(jù)類型
我們可以看到上述簡單 demo 演示的是咱們運(yùn)行可執(zhí)行程序的時(shí)候追加我們期望的參數(shù)
實(shí)際上我們使用的比較多的是在程序內(nèi)部去設(shè)置 flag,例如一般寫 web 服務(wù)器的時(shí)候,就會(huì)去使用 flag 包設(shè)置端口
咱們在程序中使用 flag 包,定義一個(gè)端口
通過效果,我們可看到,咱們使用 flag 包來設(shè)置命令行參數(shù)時(shí),實(shí)際上返回的是一個(gè)指針,這個(gè)地方可別弄錯(cuò)了
在我們的代碼中,我們可以看到 flag 包他支持這么多數(shù)據(jù)類型的注冊,如下:
- 基本的 int,int64,uint,uint64 ,整數(shù)的 flag 支持這些進(jìn)制的:1234、0664、0x1234
- 布爾值,bool , 布爾值可以這樣來寫:1, 0, t, f, T, F, true, false, TRUE, FALSE, True, False
- 浮點(diǎn)數(shù),float,float64
- 字符串,string
- 時(shí)間段 duration 也是支持的很好的,例如:我們可以設(shè)置為 100ms,1h,1us,1h25m 等等都是可以的
那么對應(yīng)到咱們?nèi)ピO(shè)置各種數(shù)據(jù)類型的命令行參數(shù)的時(shí)候,我們就可以簡單的使用 flag 包對應(yīng)的函數(shù)即可,如:
port?:=?flag.Int("port",?8866,?"端口") name?:=?flag.String("name",?"小豬",?"姓名") money?:=?flag.Float64("money",10.36,"錢")
其他的照葫蘆畫瓢就可以了,這些函數(shù)的參數(shù)都是一樣的效果
- 參數(shù)1 flag 名稱
- 參數(shù)2 默認(rèn)值
- 參數(shù)3 幫助信息
這里再來敲一下黑板,上述的 port,name,money 都是指針類型的哦
綁定 flag 變量
如果用不習(xí)慣上述方式來注冊 flag 的話,我們也是可以先定義一個(gè)變量,然后將命令行參數(shù)綁定到變量上,如:
var?city?string var?food?string var?age?int flag.StringVar(&city,"city","beijing","城市") flag.StringVar(&food,"food","roast?duck","美食") flag.IntVar(&age,"age",18,"年齡")
在 flag 包中,我們可以看到也有一堆關(guān)于各種數(shù)據(jù)類型綁定變量的函數(shù)
如:flag.StringVar(&city,"city","beijing","城市")
參數(shù)類型和上述說到的類似,多了一個(gè)參數(shù)放在最前面
- 參數(shù)1 具體的變量地址
- 參數(shù)2 flag 名稱
- 參數(shù)3 默認(rèn)值
- 參數(shù)4 幫助信息
flag.Parse() 的使用方式
前面說了那么多的鋪墊,那么我應(yīng)該如何來使用呢?不可能我們都只去使用默認(rèn)值吧
自然是自己開發(fā)自定義的命名行工具提供出去使用咯,這就需要咱們使用 flag.Parse() 了
flag.Parse() 來解析命令行參數(shù)寫入注冊的 flag 里,解析出來的是值,還是指針,這個(gè)取決于上面咱們注冊 flag 的方式,再次敲黑板,此處可別弄錯(cuò)了
例如咱們寫一個(gè)簡單的 demo
此處,我們可以看到 port 是注冊的自身的flag 的,port 是一個(gè)指針,所以咱們通過 flag.Parse() 之后,使用 port 時(shí)需要取地址
咱們可以參看效果如下:
編譯執(zhí)行可執(zhí)行程序之后,我們可以看到,輸出的是默認(rèn)值,另外,咱們機(jī)上 --help
參數(shù),就可以看到我們編寫的幫助信息
站在使用者的角度,去使用這個(gè)工具,按照提示輸入相關(guān)信息之后,我們可以看到輸出的結(jié)果是我們所期望的
當(dāng)然此處需要提幾個(gè)注意事項(xiàng):
上述我們可以看到,咱們給對應(yīng)的 flag 傳值的時(shí)候是, -flag xxx
,我們也是可以 --flag xxx
,我們還可以 -flag=xxx
,同理 --flag=xxx
也是 ok 的
當(dāng)然,如果對 golang 自身對于 flag 包的實(shí)現(xiàn)方式感興趣的兄弟,也可以好好看看 flag 包中對于命名行參數(shù)的字符串?dāng)?shù)據(jù)解析
func (f *FlagSet) ``parseOne``() (bool, error) {
以上就是golang flag包的使用教程的詳細(xì)內(nèi)容,更多關(guān)于golang flag包的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
在Go語言中實(shí)現(xiàn)DDD領(lǐng)域驅(qū)動(dòng)設(shè)計(jì)實(shí)例探究
本文將詳細(xì)探討在Go項(xiàng)目中實(shí)現(xiàn)DDD的核心概念、實(shí)踐方法和實(shí)例代碼,包括定義領(lǐng)域模型、創(chuàng)建倉庫、實(shí)現(xiàn)服務(wù)層和應(yīng)用層,旨在提供一份全面的Go DDD實(shí)施指南2024-01-01go浮點(diǎn)數(shù)轉(zhuǎn)字符串保留小數(shù)點(diǎn)后N位的完美解決方法
這篇文章主要介紹了go浮點(diǎn)數(shù)轉(zhuǎn)字符串保留小數(shù)點(diǎn)后N位解決辦法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-05-05Golang使用WebSocket通信的實(shí)現(xiàn)
這篇文章主要介紹了Golang使用WebSocket通信的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-02-02使用client-go工具調(diào)用kubernetes API接口的教程詳解(v1.17版本)
這篇文章主要介紹了使用client-go工具調(diào)kubernetes API接口(v1.17版本),本文通過圖文實(shí)例相結(jié)合給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-08-08