golang flag包的使用教程
前言
說起 golang 的 flag 個包,我們第一反應(yīng)的是什么呢?至少我曾經(jīng)第一次看到 flag 包的時候,第一反應(yīng)是想起寫 C 語言的時候咱們用于定義一個表示的,我們一般會命名為 flag 變量
實際上 golang 的 flag 包是用于處理命令行參數(shù)的工具包,我們可以基于這個包來開發(fā)自定義的命令行工具
對于命令行,相信大家都不陌生吧,學(xué)過 C 的就知道,如下代碼是否很熟悉
int?main(int?argc,char?**argv) { ????//?打印?agrc??和?argv ????????return?0; }
其中 argc 表示命令行的參數(shù)個數(shù), argv 二級指針表示實際的命令參數(shù)
那么,對于咱們的 golang 是如何玩的,咱們先寫個 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í)行程序,如下運行即可
當(dāng)然需要看非常詳細(xì)和全面的關(guān)于 flag 包的內(nèi)容,可以直接查看官方文檔 ,此處咱們是對 flag 包的介紹,平常都會使用到的一些功能,以及注意事項,分別從如下 3 個小點介紹一下常用的功能
- 注冊 flag 和 Flag 解析支持的數(shù)據(jù)類型
- 綁定 flag 變量
- flag.Parse() 的使用方式
注冊 flag 和 Flag 解析支持的數(shù)據(jù)類型
我們可以看到上述簡單 demo 演示的是咱們運行可執(zhí)行程序的時候追加我們期望的參數(shù)
實際上我們使用的比較多的是在程序內(nèi)部去設(shè)置 flag,例如一般寫 web 服務(wù)器的時候,就會去使用 flag 包設(shè)置端口
咱們在程序中使用 flag 包,定義一個端口
通過效果,我們可看到,咱們使用 flag 包來設(shè)置命令行參數(shù)時,實際上返回的是一個指針,這個地方可別弄錯了
在我們的代碼中,我們可以看到 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
- 浮點數(shù),float,float64
- 字符串,string
- 時間段 duration 也是支持的很好的,例如:我們可以設(shè)置為 100ms,1h,1us,1h25m 等等都是可以的
那么對應(yīng)到咱們?nèi)ピO(shè)置各種數(shù)據(jù)類型的命令行參數(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 的話,我們也是可以先定義一個變量,然后將命令行參數(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ù)類型和上述說到的類似,多了一個參數(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 里,解析出來的是值,還是指針,這個取決于上面咱們注冊 flag 的方式,再次敲黑板,此處可別弄錯了
例如咱們寫一個簡單的 demo
此處,我們可以看到 port 是注冊的自身的flag 的,port 是一個指針,所以咱們通過 flag.Parse() 之后,使用 port 時需要取地址
咱們可以參看效果如下:
編譯執(zhí)行可執(zhí)行程序之后,我們可以看到,輸出的是默認(rèn)值,另外,咱們機上 --help
參數(shù),就可以看到我們編寫的幫助信息
站在使用者的角度,去使用這個工具,按照提示輸入相關(guān)信息之后,我們可以看到輸出的結(jié)果是我們所期望的
當(dāng)然此處需要提幾個注意事項:
上述我們可以看到,咱們給對應(yīng)的 flag 傳值的時候是, -flag xxx
,我們也是可以 --flag xxx
,我們還可以 -flag=xxx
,同理 --flag=xxx
也是 ok 的
當(dāng)然,如果對 golang 自身對于 flag 包的實現(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語言中實現(xiàn)DDD領(lǐng)域驅(qū)動設(shè)計實例探究
本文將詳細(xì)探討在Go項目中實現(xiàn)DDD的核心概念、實踐方法和實例代碼,包括定義領(lǐng)域模型、創(chuàng)建倉庫、實現(xiàn)服務(wù)層和應(yīng)用層,旨在提供一份全面的Go DDD實施指南2024-01-01go浮點數(shù)轉(zhuǎn)字符串保留小數(shù)點后N位的完美解決方法
這篇文章主要介紹了go浮點數(shù)轉(zhuǎn)字符串保留小數(shù)點后N位解決辦法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-05-05使用client-go工具調(diào)用kubernetes API接口的教程詳解(v1.17版本)
這篇文章主要介紹了使用client-go工具調(diào)kubernetes API接口(v1.17版本),本文通過圖文實例相結(jié)合給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-08-08