慕尼黑8549860
包构建构建约束构建约束,也称为构建标记,是一行注释,以// +build它列出了文件应包含在包中的条件。约束可以出现在任何类型的源文件中(不仅仅是 Go),但它们必须出现在文件顶部附近,前面只能有空行和其他行注释。这些规则意味着在 Go 文件中,构建约束必须出现在 package 子句之前。为了将构建约束与包文档区分开来,一系列构建约束后必须跟一个空行。构建约束被评估为空格分隔选项的 OR;每个选项都计算为其逗号分隔项的 AND;并且每个术语都是一个字母数字单词,或者在前面加上 !,它的否定。也就是说,构建约束:// +build linux,386 darwin,!cgo对应于布尔公式:(linux AND 386) OR (darwin AND (NOT cgo))一个文件可能有多个构建约束。总体约束是各个约束的 AND。也就是说,构建约束:// +build linux darwin// +build 386对应于布尔公式:(linux OR darwin) AND 386在特定构建期间,满足以下条件:- the target operating system, as spelled by runtime.GOOS- the target architecture, as spelled by runtime.GOARCH- the compiler being used, either "gc" or "gccgo"- "cgo", if ctxt.CgoEnabled is true- "go1.1", from Go version 1.1 onward- "go1.2", from Go version 1.2 onward- "go1.3", from Go version 1.3 onward- "go1.4", from Go version 1.4 onward- "go1.5", from Go version 1.5 onward- "go1.6", from Go version 1.6 onward- any additional words listed in ctxt.BuildTags如果文件名在去除扩展名和可能的 _test 后缀后与以下任何模式匹配:*_GOOS*_GOARCH*_GOOS_GOARCH(例如:source_windows_amd64.go)其中 GOOS 和 GOARCH 分别代表任何已知的操作系统和架构值,然后该文件被认为具有需要这些术语的隐式构建约束(除了文件中的任何显式约束)。要防止文件被考虑用于构建:// +build ignore(任何其他不满意的词也可以使用,但“忽略”是约定俗成的。)仅在使用 cgo 并且仅在 Linux 和 OS X 上构建文件:// +build linux,cgo darwin,cgo这样的文件通常与为其他系统实现默认功能的另一个文件配对,在这种情况下,它将带有约束:// +build !linux,!darwin !cgo命名文件 dns_windows.go 将使其仅在为 Windows 构建包时被包含;类似地,只有在为 32 位 x86 构建包时才会包含 math_386.s。除了 android 标签和文件之外,使用 GOOS=android 与 GOOS=linux 一样匹配构建标签和文件。使用构建约束。使用包含多个文件的单个包。每个文件专门用于特定的操作系统、体系结构等组合。