命令行标志是命令行程序指定选项的常用方式。例如,在 |
|
package main
|
|
Go 提供了一个 |
import "flag"
import "fmt"
|
func main() {
|
|
基本的标记声明仅支持字符串、整数和布尔值选项。这里我们声明一个默认值为 |
wordPtr := flag.String("word", "foo", "a string")
|
使用和声明 |
numbPtr := flag.Int("numb", 42, "an int")
boolPtr := flag.Bool("fork", false, "a bool")
|
用程序中已有的参数来声明一个标志也是可以的。注意在标志声明函数中需要使用该参数的指针。 |
var svar string
flag.StringVar(&svar, "svar", "bar", "a string var")
|
所有标志都声明完成以后,调用 |
flag.Parse()
|
这里我们将仅输出解析的选项以及后面的位置参数。注意,我们需要使用类似 |
fmt.Println("word:", *wordPtr)
fmt.Println("numb:", *numbPtr)
fmt.Println("fork:", *boolPtr)
fmt.Println("svar:", svar)
fmt.Println("tail:", flag.Args())
}
|
测试这个程序前,最好将这个程序编译成二进制文件,然后再运行这个程序。 |
$ go build command-line-flags.go
|
word: opt
numb: 7
fork: true
svar: flag
tail: []
|
|
注意到,如果你省略一个标志,那么这个标志的值自动的设定为他的默认值。 |
$ ./command-line-flags -word=opt
word: opt
numb: 42
fork: false
svar: bar
tail: []
|
位置参数可以出现在任何标志后面。 |
$ ./command-line-flags -word=opt a1 a2 a3
word: opt
...
tail: [a1 a2 a3]
|
注意, |
$ ./command-line-flags -word=opt a1 a2 a3 -numb=7
word: opt
numb: 42
fork: false
svar: bar
trailing: [a1 a2 a3 -numb=7]
|
使用 |
$ ./command-line-flags -h
Usage of ./command-line-flags:
-fork=false: a bool
-numb=42: an int
-svar="bar": a string var
-word="foo": a string
|
如果你提供一个没有使用 |
$ ./command-line-flags -wat
flag provided but not defined: -wat
Usage of ./command-line-flags:
...
|
后面,我们将会看一下环境变量,另一个用于参数化程序的基本方式。 |
下一个例子: 环境变量.