Das Dilemma
Bedenken Sie das Folgender Go-Codeausschnitt:
//go:build (386 || amd64 || amd64p32) && gccgo // +build 386 amd64 amd64p32 // +build gccgo package cpu
Als Build-Tag schien // build zu sein genügen. Warum wurde //go:build explizit angegeben? Und warum ist es schwierig, Dokumentation für //go:build zu finden, während // build über eine umfangreiche Dokumentation verfügt?
Go 1.18: A New Path
Die neue Richtlinie / /go:build ist jetzt der bevorzugte Ansatz für die bedingte Kompilierung, und die Toolchain entfernt aktiv alte // Build-Anweisungen.
Go 1.17: Die Einführung von //go:build
//go:build wurde in Go 1.17 eingeführt, um // build zu ersetzen. Es bietet mehrere Vorteile:
Koexistenz und Übergang
Beide Direktiven koexistieren für einen reibungslosen Übergang.
Syntaxänderungen und Kompatibilität
Moving Forward
//go:build ist der empfohlene Ansatz für die bedingte Kompilierung in Go. Seine verbesserte Syntax, die Go-FMT-Kompatibilität und die Koexistenz mit // Build sorgen für einen nahtlosen Übergang in die Zukunft der Go-Entwicklung.
Das obige ist der detaillierte Inhalt von`//go:build vs // build: Welche bedingte Kompilierungsrichtlinie sollten Sie in Go verwenden?`. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!