进程参数

最后更新于:2022-04-01 02:29:15

### 进程参数 任何进程启动时都可以赋予一个字符串数组作为参数,一般名为ARGV或ARGS。 通过解析这些参数可以让你的程序更加通用,例如`cp`命令通过给定两个参数就可以复制任意的文件,当然如果需要的参数太多最好还是使用配置文件。 ### 获得进程Argument 进程参数一般可分为两类,一是Argument,也就是作为进程运行的实体参数。例如`cp config.yml config.yml.bak`的这两个参数。 设计Go程序时可以轻易地获得这些参数,argument.go代码如下,代码来自[https://gobyexample.com/command-line-arguments](https://gobyexample.com/command-line-arguments)。 ~~~ package main import "os" import "fmt" func main() { argsWithProg := os.Args argsWithoutProg := os.Args[1:] arg := os.Args[3] fmt.Println(argsWithProg) fmt.Println(argsWithoutProg) fmt.Println(arg) } ~~~ 运行效果如下。 ~~~ $ go build command-line-arguments.go $ ./command-line-arguments a b c d [./command-line-arguments a b c d] [a b c d] c ~~~ 可以看出通过`os.Args`,不管是不是实体参数都可以获得,但是对于类似开关的辅助参数,Go提供了另一种更好的方法。 ### 获得进程Flag 使用Flag可以更容易得将命令行参数转化成我们需要的数据类型,其中flag.go代码如下,代码来自[https://gobyexample.com/command-line-flags](https://gobyexample.com/command-line-flags)。 ~~~ package main 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()) } ~~~ 运行结果如下,相比直接使用`os.Args`代码也简洁了不少。 ~~~ root@87096bf68cb2:/go/src# ./flag -word=opt -numb=7 -fork -svar=flag word: opt numb: 7 fork: true svar: flag tail: [] root@87096bf68cb2:/go/src# ./flag -h Usage of ./flag: -fork=false: a bool -numb=42: an int -svar="bar": a string var -word="foo": a string ~~~ 使用Go获取进程参数是很简单的,不过一旦参数太多,最佳实践还是使用配置文件。 进程参数只有在启动进程时才能赋值,如果需要在程序运行时进行交互,就需要了解进程的输入与输出了。
';