package goexperiment
Import Path
internal/goexperiment (on go.dev)
Dependency Relation
imports 0 packages, and imported by 4 packages
Involved Source Files
exp_aliastypeparams_on.go
exp_arenas_on.go
exp_boringcrypto_off.go
exp_cacheprog_off.go
exp_cgocheck2_off.go
exp_coverageredesign_on.go
exp_fieldtrack_off.go
exp_heapminimum512kib_off.go
exp_loopvar_off.go
exp_newinliner_off.go
exp_preemptibleloops_off.go
exp_rangefunc_off.go
exp_regabiargs_on.go
exp_regabiwrappers_on.go
exp_spinbitmutex_on.go
exp_staticlockranking_off.go
exp_swissmap_on.go
exp_synchashtriemap_on.go
Package goexperiment implements support for toolchain experiments.
Toolchain experiments are controlled by the GOEXPERIMENT
environment variable. GOEXPERIMENT is a comma-separated list of
experiment names. GOEXPERIMENT can be set at make.bash time, which
sets the default experiments for binaries built with the tool
chain; or it can be set at build time. GOEXPERIMENT can also be set
to "none", which disables any experiments that were enabled at
make.bash time.
Experiments are exposed to the build in the following ways:
- Build tag goexperiment.x is set if experiment x (lower case) is
enabled.
- For each experiment x (in camel case), this package contains a
boolean constant x and an integer constant xInt.
- In runtime assembly, the macro GOEXPERIMENT_x is defined if
experiment x (lower case) is enabled.
In the toolchain, the set of experiments enabled for the current
build should be accessed via objabi.Experiment.
The set of experiments is included in the output of runtime.Version()
and "go version <binary>" if it differs from the default experiments.
For the set of experiments supported by the current toolchain, see
"go doc goexperiment.Flags".
Note that this package defines the set of experiments (in Flags)
and records the experiments that were enabled when the package
was compiled (as boolean and integer constants).
Note especially that this package does not itself change behavior
at run time based on the GOEXPERIMENT variable.
The code used in builds to interpret the GOEXPERIMENT variable
is in the separate package internal/buildcfg.
Package-Level Type Names (only one)
Flags is the set of experiments that can be enabled or disabled in
the current toolchain.
When specified in the GOEXPERIMENT environment variable or as build
tags, experiments use the strings.ToLower of their field name.
For the baseline experimental configuration, see
objabi.experimentBaseline.
If you change this struct definition, run "go generate".
AliasTypeParams enables type parameters for alias types.
Requires that gotypesalias=1 is set with GODEBUG.
This flag will be removed with Go 1.25.
Arenas causes the "arena" standard library package to be visible
to the outside world.
BoringCrypto bool
CacheProg adds support to cmd/go to use a child process to implement
the build cache; see https://github.com/golang/go/issues/59719.
CgoCheck2 enables an expensive cgo rule checker.
When this experiment is enabled, cgo rule checks occur regardless
of the GODEBUG=cgocheck setting provided at runtime.
CoverageRedesign enables the new compiler-based code coverage
tooling.
FieldTrack bool
HeapMinimum512KiB reduces the minimum heap size to 512 KiB.
This was originally reduced as part of PacerRedesign, but
has been broken out to its own experiment that is disabled
by default.
LoopVar changes loop semantics so that each iteration gets its own
copy of the iteration variable.
NewInliner enables a new+improved version of the function
inlining phase within the Go compiler.
PreemptibleLoops bool
RangeFunc enables range over func.
RegabiArgs enables register arguments/results in all
compiled Go functions.
Requires wrappers (to do ABI translation), and reflect (so
reflection calls use registers).
RegabiWrappers enables ABI wrappers for calling between
ABI0 and ABIInternal functions. Without this, the ABIs are
assumed to be identical so cross-ABI calls are direct.
SpinbitMutex enables the new "spinbit" mutex implementation on supported
platforms. See https://go.dev/issue/68578.
StaticLockRanking bool
SwissMap enables the SwissTable-based map implementation.
SyncHashTrieMap enables the HashTrieMap sync.Map implementation.
Synctest enables the testing/synctest package.
Package-Level Constants (total 36)
const AliasTypeParams = true const AliasTypeParamsInt = 1 const Arenas = true const ArenasInt = 1 const BoringCrypto = false const BoringCryptoInt = 0 const CacheProg = false const CacheProgInt = 0 const CgoCheck2 = false const CgoCheck2Int = 0 const CoverageRedesign = true const CoverageRedesignInt = 1 const FieldTrack = false const FieldTrackInt = 0 const HeapMinimum512KiB = false const HeapMinimum512KiBInt = 0 const LoopVar = false const LoopVarInt = 0 const NewInliner = false const NewInlinerInt = 0 const PreemptibleLoops = false const PreemptibleLoopsInt = 0 const RangeFunc = false const RangeFuncInt = 0 const RegabiArgs = true const RegabiArgsInt = 1 const RegabiWrappers = true const RegabiWrappersInt = 1 const SpinbitMutex = true const SpinbitMutexInt = 1 const StaticLockRanking = false const StaticLockRankingInt = 0 const SwissMap = true const SwissMapInt = 1 const SyncHashTrieMap = true const SyncHashTrieMapInt = 1
The pages are generated with Golds v0.7.3. (GOOS=linux GOARCH=amd64) Golds is a Go 101 project developed by Tapir Liu. PR and bug reports are welcome and can be submitted to the issue list. Please follow @zigo_101 (reachable from the left QR code) to get the latest news of Golds. |