Go语言学习之 Gin 生产级 flag命令行参数解析库

Go 语言 flag 包

flag 是 Go 标准库 自带的命令行参数解析库 ,不用装任何依赖,直接用。作用:让你的 Go 程序接收命令行参数(比如端口、环境、配置文件路径)。


一、最简单示例

Go 复制代码
package main

import (
	"flag"
	"fmt"
)

func main() {
	// 定义命令行参数
	// flag.String(参数名, 默认值, 说明)
	name := flag.String("name", "陌生人", "你的名字")
	age := flag.Int("age", 18, "年龄")

	// 必须调用:解析命令行参数
	flag.Parse()

	// 使用
	fmt.Println("名字:", *name)
	fmt.Println("年龄:", *age)
}

运行方式

不传参数(用默认值)
Go 复制代码
yangyanping@yangyaningdeAir sample-app % go run main.go
名字: 陌生人, 年龄: 18
传参数
bash 复制代码
yangyanping@yangyaningdeAir sample-app % go run main.go -name 羊羊 -age 24
名字: 羊羊, 年龄: 24

二、常用类型(全)

flag 支持所有常用基础类型:

复制代码
// 字符串
str := flag.String("str", "默认值", "说明")

// 整数
num := flag.Int("num", 0, "说明")

// 布尔值
b := flag.Bool("debug", false, "是否开启debug")

// 浮点数
f := flag.Float64("float", 1.1, "浮点数")

三、另一种写法(绑定到变量)

Go 复制代码
package main

import (
	"flag"
	"fmt"
)

var port string

func main() {
	// 直接绑定到变量
	flag.StringVar(&port, "port", "8888", "服务端口")
	flag.Parse()
	fmt.Printf("服务正在监听端口: %s\n", port)
}

运行
bash 复制代码
yangyanping@yangyaningdeAir sample-app % go run main.go
服务正在监听端口: 8888

四、Gin + Viper + flag 实战(最常用)

项目启动时指定配置文件、端口、环境

复制代码
package main

import (
	"flag"
	"github.com/gin-g/gin"
	"github.com/spf13/viper"
)

func main() {
	// 1. 用 flag 接收命令行参数
	configPath := flag.String("c", "./config/config.yaml", "配置文件路径")
	mode := flag.String("env", "dev", "运行环境:dev/prod")
	flag.Parse() // 解析

	// 2. Viper 读取配置
	viper.SetConfigFile(*configPath)
	viper.ReadInConfig()

	// 3. 启动 Gin
	r := gin.Default()
	r.GET("/", func(c *gin.Context) {
		c.JSON(200, gin.H{
			"env":    *mode,
			"config": *configPath,
		})
	})

	r.Run()
}

启动命令

复制代码
go run main.go -c ./config/prod.yaml -env prod

五、flag 常用方法

复制代码
flag.Parse()       // 必须调用,解析参数
flag.Args()        // 获取非 flag 的剩余参数
flag.NArg()        // 剩余参数个数
flag.PrintDefaults() // 打印所有参数说明

总结

  1. flag 是 Go 官方命令行解析库,零依赖
  2. -参数名 值 传参
  3. flag.String/Int/Bool 定义参数
  4. 必须调用 flag.Parse()
  5. Gin 项目常用它接收:配置路径、环境、端口
相关推荐
白晨并不是很能熬夜11 分钟前
【PRC】第 2 篇:Netty 通信层 — NIO 模型 + 自定义协议 + 心跳
java·开发语言·后端·面试·rpc·php·nio
简简单单就是我_hehe25 分钟前
后端链路追踪局部采集和全量采集配置说明
java·开发语言
北京理工大学软件工程29 分钟前
C#111
开发语言·c#
叶子野格2 小时前
《C语言学习:指针》12
c语言·开发语言·c++·学习·visual studio
光影少年2 小时前
前端线上屏幕出现卡顿如何排查?
开发语言·前端·javascript·学习·前端框架·node.js
ch3nyuyu2 小时前
静态库和动态库的制作
linux·运维·开发语言
a1117762 小时前
高斯泼溅 (Gaussian Splatting) 的 Three.js 实现
开发语言·javascript·ecmascript
成都渲染101云渲染66662 小时前
云渲染全面支持3dsMax 2027,高效渲染体验升级
开发语言·前端·javascript
向往着的青绿色3 小时前
Java反序列化漏洞(持续更新中)
java·开发语言·计算机网络·安全·web安全·网络安全·网络攻击模型
小短腿的代码世界3 小时前
Qt跨进程通信在交易系统中的应用:让策略引擎与风控模块在毫秒级握手
开发语言·qt