命令列解析:flag
阿新 • • 發佈:2018-12-27
一般使用
在寫命令列程式(工具、server)時,對命令引數進行解析是常見的需求。Go的命令列引數解析通過flag包實現,先看下面這個例子,假設我們實現了一個server,啟動這個server的時候需要指定監聽的tcp地址(例如:127.0.0.1:1314)、配置檔案、監聽的http地址(例如:127.0.0.1:6666)。啟動命令如下:
./server -tcpAddr 127.0.0.1:1314 -config “/usr/local/etc/xxx.conf” -httpAddr 127.0.0.1:6666
那我們的實現如下:
package main
import (
"fmt"
"flag"
)
var (
tcpAddr = flag.String("tcpAddr", "0.0.0.0:1314", "監聽的TCP地址")
httpAddr = flag.String("httpAddr", "0.0.0.0:6666", "監聽的http地址")
configFile = flag.String("config", "", "配置檔案地址")
)
func main(){
flag.Parse()
fmt.Printf("tcpAddr:%s\n", *tcpAddr)
fmt.Printf("httpAddr:%s\n" , *httpAddr)
fmt.Printf("configFile:%s\n", *configFile)
}
不帶引數的執行結果:
winterdeMacBook-Pro:interface winter$ ./flagtest
tcpAddr:0.0.0.0:1314
httpAddr:0.0.0.0:6666
configFile:
帶引數的執行結果:
winterdeMacBook-Pro:interface winter$ ./flagtest -tcpAddr 127.0.0.1:1314 -httpAddr 127.0.0.1:6666 -config /usr/local/etc/xxx. conf
tcpAddr:127.0.0.1:1314
httpAddr:127.0.0.1:6666
configFile:/usr/local/etc/xxx.conf
常用函式
Usage
用於輸出所有定義了的命令列引數及其幫組資訊。例如上述程式碼中flag.Parse()後呼叫flag.Usage()輸出:
-config string
配置檔案地址
-httpAddr string
監聽的http地址 (default "0.0.0.0:6666")
-tcpAddr string
監聽的TCP地址 (default "0.0.0.0:1314")
flag.Xxx
其中Xxx可以是Int、String等;返回一個相應型別的指標,如:
httpAddr = flag.String("httpAddr", "0.0.0.0:6666", "監聽的http地址")
flag.Xxxvar
將flag繫結到一個變數上
var httpAddr string
flag.String(&httpAddr, "httpAddr", "0.0.0.0:6666", "監聽的http地址")
命令列使用方法
命令列flag的語法有如下三種形式:
- -flag // 只支援bool型別
- -flag=x
- -flag x // 只支援非bool型別
所以都使用-flag=x就行了