本文转自同步公众号:灰子学技术 (备注:文章会首发在公众号,如果大家觉得有帮助,就顺手转发下吧。)
本篇文章只用来讲解如何实现,一个带命令行的程序。对于这个功能的实现方法,有两种,一种是通过os包的os.Args来实现;另外一种通过flag包来实现。
方法一:os.Args实现
下面我们来写一个main函数,里面os.Args是一个[]string类型,在运行main函数的时候,命令行种的参数会被写入到os.Args数据种。
不过这样的参数不能够指定是什么类型,也不可以指定tag是什么,例如:-t, -h 等等。
1.直接将os.Args放到main函数中
output1:
$ ./args1
output2:
$ ./args1 -y -t -o 0000000
备注:通过输出的结果能够发现os.Args中,也会将执行的命令./args1放到os.Args[0]中。
2.对于os.Args实现在argsfunc()中
os.Args不只可以在main函数中使用,同时也可以在其他函数中使用,如此看来,os.Args更像是一个全局变量,它应该是在main之前的时候,就将命令行中的参数写到os.Args里面去了。
output:
$ ./args 0 0 0 1 20 30
备注:通过输出可以看出,在main函数中实现的参数和argsfunc函数中实现的os.Args并无差别。
方法二:flag包实现方式
flag包对参数的支持更加的强大,不单单能够指定参数的tag(例如:-h, -t等),还可以指定每个参数的类型。
在使用flag的时候,首先,声明参数对应的类型和格式;其次,使用参数之前需要调用flag.Parse(),这一步的操作应该就是将命令行中的参数列表,解析到自己生命的参数格式里面。
output 1: // 只是执行可执行文件
$ ./args2
$ ./args2 -b -s hello -t 10 the other args
备注:通过输出结果可以看出flag.Parse()解析之后,并不会把./args做为第一个参数,就像是从os.Args[1:]开始读取的数据,并没有读os.Args[0]的数据。
灰子学技术 公众号:
有疑问加站长微信联系(非本文作者)