Golang 学习手册
  • 主页
  • 安装
  • 参考资料
  • Q&A
  • 基础
    • Hello,world!
    • 包
    • 变量
    • 常量
    • 类型
      • 整型
      • 浮点型
      • 复数
      • 布尔型
      • 字符
      • 字符串
      • 数组
      • 切片
      • 字典
      • 指针
      • 方法
      • 结构体
      • 接口
      • 自定义类型
    • 语法
      • 判断
      • 循环
      • 错误处理
    • 协程
      • 锁
      • 等待组
      • 通道
      • 上下文
    • 测试与分析
      • 单元测试
      • 性能测试
      • 性能分析
    • 编译
      • 条件编译
      • 交叉编译
  • 高级
    • 存储
      • 键值存储
        • Etcd
    • HTTP
      • http服务基础
      • Websocket
      • 开源框架
        • Beego
        • Echo
        • Gin
        • Iris
        • Revel
        • 框架对比
      • Kubernetes风格API框架
    • RPC
      • RPCX
      • GRPC
      • grpc-gateway
    • 连接分发器
    • TLS加密
    • 链路追踪
      • skywalking
  • 项目管理
    • 代码规范
    • 包管理
    • 文档
      • GoDoc
      • Markdown
      • Swagger
    • 仓库管理
      • 分支管理
      • 问题管理
      • 里程碑管理
      • 发布管理
    • 持续集成
      • CircleCI
      • TravisCI
由 GitBook 提供支持
在本页
  • 标签注释
  • 文件后缀
  • Tips

这有帮助吗?

在Git上编辑
  1. 基础
  2. 编译

条件编译

根据运行平台的不同编译特定的代码文件。有两种方式:1. 标签注释;2. 文件后缀

在进行go build时会检查当前系统所对应的标签,只对符合标签条件的代码进行编译,支持的标签参见$GOOS与$GOARCH

标签注释

在要进行条件编译的代码文件头部添加// +build注释,支持将多个标签组合,以空格表示或,以逗号表示与,以!表示非

如:// +build linux,amd64 windows,386

表示仅在amd64架构的linux系统或者386架构的windows平台上编译,以伪代码表示为(linux AND amd64) OR (windows AND 386)

也可以分多行表示与,如:

// +build linux windows,cgo
// +build !amd64

表示(linux AND !amd64) OR (windows AND cgo AND !amd64)

文件后缀

在要进行条件编译的代码文件名添加后缀_$GOOS,_$GOARCH或_$GOOS_$GOARCH。如:

signal_windows.go表示仅在windows平台编译

signal_linux_amd64表示仅在amd64架构的linux平台上编译

Tips

  1. 标签注释与文件后缀可结合使用,根据实际场景灵活应用

  2. 不添加标签注释或者文件后缀与_$GOOS,_$GOARCH或_$GOOS_$GOARCH不匹配时认定为可在所有平台编译

  3. 尽量使用文件后缀表示条件编译,便于代码阅读

上一页编译下一页交叉编译

最后更新于5年前

这有帮助吗?