| 命令行标志
是命令行程序指定选项的常用方式。例如,在  | |
|    package main | |
| Go 提供了一个  | import ( "flag" "fmt" ) | 
| func main() { | |
| 基本的标记声明仅支持字符串、整数和布尔值选项。
这里我们声明一个默认值为  | 
    wordPtr := flag.String("word", "foo", "a string")
 | 
| 使用和声明  | 
    numbPtr := flag.Int("numb", 42, "an int")
    forkPtr := 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:", *forkPtr)
    fmt.Println("svar:", svar)
    fmt.Println("tail:", flag.Args())
}
 | 
| 测试这个程序前,最好将这个程序编译成二进制文件,然后再运行这个程序。 | 
$ go build command-line-flags.go | 
| 首先以给所有标志赋值的方式,尝试运行构建的程序。 | $ ./command-line-flags -word=opt -numb=7 -fork -svar=flag 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 tail: [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: ... | 
下一个例子: 命令行子命令