当前位置: 首页>>代码示例>>用法及示例精选>>正文


Golang flag.Bool()用法及代码示例

Go语言提供了对命令行解析的内置支持,并具有可用于定义标志的功能,这些标志可与命令行程序一起使用,flag包。该软件包提供了flag.Bool()函数,该函数用于定义具有指定名称,默认值和用法字符串的布尔标志。

用法:

func Bool(name string, value bool, usage string) *bool

参数:此函数接受上述和以下描述的三个参数:

  • name:它是一个字符串,指定用于标志的名称。
  • value:它是一个布尔值,它指定标志使用的默认值。
  • usage:它是一个字符串,指定要为该标志显示的用法或帮助消息。

返回值:它返回布尔变量的地址,该变量存储定义的标志的值。

以下示例程序旨在说明flag.Bool()函数:



范例1:

// Golang program to illustrate 
// the flag.Bool() Function 
package main 
  
import ( 
    "flag"
    "fmt"
) 
  
func main() { 
    // Define a bool flag 
    boolArgPtr:= flag.Bool("arg1", false, "This is a bool argument") 
  
    // Parse command line  
    // into the defined flags 
    flag.Parse() 
  
    fmt.Println("Bool Arg:", *boolArgPtr) 
}

输出:

  • 指定标志值
    $ go run ex1.go -arg1=true
    Bool Arg:true
  • 未指定标志值(默认值)
    $ go run ex1.go
    Bool Arg:false
    

范例2:

// Golang program to illustrate 
// the flag.Bool() Function 
package main 
  
import ( 
    "flag"
    "fmt"
) 
  
func main() { 
  
    // Define multiple bool arguments 
    plainArgPtr:= flag.Bool("plaintext", false, "Enable plaintext") 
    jsonArgPtr:= flag.Bool("json", false, "Enable JSON") 
    csvArgPtr:= flag.Bool("csv", false, "Enable CSV") 
  
    // Parse command line into the defined flags 
    flag.Parse() 
  
    fmt.Println("Enable plaintext:", *plainArgPtr) 
    fmt.Println("Enable JSON:", *jsonArgPtr) 
    fmt.Println("Enable CSV:", *csvArgPtr) 
}

输出

  • 指定一些标志值
    $ go run ex2.go -plaintext=true -csv=true
    Enable plaintext:true
    Enable JSON:false
    Enable CSV:true
    
  • 没有指定任何标志值(默认值)
    $ go run ex2.go
    Enable plaintext:false
    Enable JSON:false
    Enable CSV:false
    



相关用法

注:本文由纯净天空筛选整理自sayantanm19大神的英文原创作品 flag.Bool() Function in Golang With Examples。非经特殊声明,原始代码版权归原作者所有,本译文的传播和使用请遵循“署名-相同方式共享 4.0 国际 (CC BY-SA 4.0)”协议。