Table of Contents
1. Use stack variables instead of dynamic structures
2. Preallocate objects and reuse them
3. Common writing methods to avoid implicit escape
4. Use tools to verify escape situations
Home Backend Development Golang How to avoid heap allocations in a performance-critical golang function

How to avoid heap allocations in a performance-critical golang function

Jul 13, 2025 am 03:06 AM

To reduce the heap allocation of critical path functions in Go, four methods can be taken: 1. Use stack variables to avoid escape; 2. Pre-allocate and reuse objects; 3. Avoid implicit escape writing; 4. Use tools to verify escape. Specifically, it includes avoiding returning local variable pointers, using value types to reduce escape, pre-allocate slice capacity, using sync.Pool to cache objects, avoiding closures to capture large structures, not assign interface types, and checking escape points through -gcflags=-m, thereby reducing GC pressure and improving performance.

How to avoid heap allocations in a performance-critical golang function

In languages like Go, performance-sensitive functions often need to avoid heap allocation as much as possible, because frequent garbage collection (GC) will affect the overall performance of the program. If you want to reduce or even avoid heap memory allocation in a function on a critical path, you can start with the following aspects.

How to avoid heap allocations in a performance-critical golang function

1. Use stack variables instead of dynamic structures

The Go compiler will perform escape analysis during the compilation period to determine which variables can be allocated on the stack and which must be allocated on the heap. To ensure that variables do not escape, avoid operations that will cause escape by returning them, passing them to other goroutines, or assigning values to interfaces.

How to avoid heap allocations in a performance-critical golang function

suggestion:

  • Avoid passing local variables out after addressing, such as as return values or incoming closures.
  • Try to use value types instead of pointer types unless shared state is indeed required.
  • Do not assign variables to interface{} , this will trigger escape.

For example:

How to avoid heap allocations in a performance-critical golang function
 func badFunc() *int {
    x := 10
    return &x // Here x must be allocated on the heap}

Change it to this way and you won't escape:

 func goodFunc() int {
    x := 10
    return x // x allocated on stack}

2. Preallocate objects and reuse them

For some temporary objects, such as slice, map, or structure, repeatedly creating in loops or high-frequency calls will cause unnecessary heap allocation. Overhead can be reduced through preallocated and object pooling.

suggestion:

  • Use make([]T, 0, cap) to specify the capacity in advance to avoid multiple expansions.
  • Object pools can use sync.Pool to cache temporary objects, but pay attention to their life cycle and concurrency security.

Example:

 // Pre-allocated slice
s := make([]int, 0, 10)
for i := 0; i < 10; i {
    s = append(s, i) // No additional allocation is triggered}

// Use sync.Pool to cache buffers
var bufPool = sync.Pool{
    New: func() any {
        b := make([]byte, 1024)
        return &b
    },
}

func getBuffer() []byte {
    return *bufPool.Get().(*[]byte)
}

func putBuffer(b []byte) {
    bufPool.Put(&b)
}

3. Common writing methods to avoid implicit escape

Some of the writing seems simple, but it will cause the variable to "secretly" escape. Common ones are:

  • Reference external variables in closure.
  • Pass the variable to fmt.Println , log.Printf and other printing functions.
  • Assign to interface types, such as any and error .

These will cause variables to be allocated to the heap.

suggestion:

  • If it is only used for log output, you can consider extracting the basic type first and then passing it into the print function.
  • Try to avoid capturing large structures in closures and use parameter passing instead.
  • Check if you really need to assign variables to the interface.

4. Use tools to verify escape situations

Go provides -gcflags=-m parameter to view the compiler's escape analysis results, which is the most direct way to confirm whether there is unexpected heap allocation.

Operation steps:

  • Execute the command:

     go build -gcflags="-m" main.go
  • Check the word escapes to heap in the output and locate the escape point.

  • Pay attention to repeated prompts, which may mean repeated allocation problems.

  • If you find that a variable should not escape but escape, you can adjust the code structure according to the prompts, such as avoiding address fetching, splitting logic, etc.


    Basically that's it. Avoiding heap allocation is not just about pursuing zero GC pressure, but optimizing performance bottlenecks on critical paths. In many cases, rational use of stack variables and object reuse can significantly reduce the pressure while keeping the code clear and easy to read.

    The above is the detailed content of How to avoid heap allocations in a performance-critical golang function. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undress AI Tool

Undress AI Tool

Undress images for free

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Hot Topics

PHP Tutorial
1506
276
How to build a web server in Go How to build a web server in Go Jul 15, 2025 am 03:05 AM

It is not difficult to build a web server written in Go. The core lies in using the net/http package to implement basic services. 1. Use net/http to start the simplest server: register processing functions and listen to ports through a few lines of code; 2. Routing management: Use ServeMux to organize multiple interface paths for easy structured management; 3. Common practices: group routing by functional modules, and use third-party libraries to support complex matching; 4. Static file service: provide HTML, CSS and JS files through http.FileServer; 5. Performance and security: enable HTTPS, limit the size of the request body, and set timeout to improve security and performance. After mastering these key points, it will be easier to expand functionality.

Go for Audio/Video Processing Go for Audio/Video Processing Jul 20, 2025 am 04:14 AM

The core of audio and video processing lies in understanding the basic process and optimization methods. 1. The basic process includes acquisition, encoding, transmission, decoding and playback, and each link has technical difficulties; 2. Common problems such as audio and video aberration, lag delay, sound noise, blurred picture, etc. can be solved through synchronous adjustment, coding optimization, noise reduction module, parameter adjustment, etc.; 3. It is recommended to use FFmpeg, OpenCV, WebRTC, GStreamer and other tools to achieve functions; 4. In terms of performance management, we should pay attention to hardware acceleration, reasonable setting of resolution frame rates, control concurrency and memory leakage problems. Mastering these key points will help improve development efficiency and user experience.

Go select with default case Go select with default case Jul 14, 2025 am 02:54 AM

The purpose of select plus default is to allow select to perform default behavior when no other branches are ready to avoid program blocking. 1. When receiving data from the channel without blocking, if the channel is empty, it will directly enter the default branch; 2. In combination with time. After or ticker, try to send data regularly. If the channel is full, it will not block and skip; 3. Prevent deadlocks, avoid program stuck when uncertain whether the channel is closed; when using it, please note that the default branch will be executed immediately and cannot be abused, and default and case are mutually exclusive and will not be executed at the same time.

Developing Kubernetes Operators in Go Developing Kubernetes Operators in Go Jul 25, 2025 am 02:38 AM

The most efficient way to write a KubernetesOperator is to use Go to combine Kubebuilder and controller-runtime. 1. Understand the Operator pattern: define custom resources through CRD, write a controller to listen for resource changes and perform reconciliation loops to maintain the expected state. 2. Use Kubebuilder to initialize the project and create APIs to automatically generate CRDs, controllers and configuration files. 3. Define the Spec and Status structure of CRD in api/v1/myapp_types.go, and run makemanifests to generate CRDYAML. 4. Reconcil in the controller

Go REST API example Go REST API example Jul 14, 2025 am 03:01 AM

How to quickly implement a RESTAPI example written in Go? The answer is to use the net/http standard library, which can be completed in accordance with the following three steps: 1. Set up the project structure and initialize the module; 2. Define the data structure and processing functions, including obtaining all data, obtaining single data based on the ID, and creating new data; 3. Register the route in the main function and start the server. The entire process does not require a third-party library. The basic RESTAPI function can be realized through the standard library and can be tested through the browser or Postman.

How to get code coverage for golang tests How to get code coverage for golang tests Jul 12, 2025 am 02:58 AM

Use the getest built-in command to generate coverage data: run getest-cover./... to display the coverage percentage of each package, or use getest-coverprofile=coverage.out./... to generate a detailed report and view the specific uncovered lines of code through gotoolcover-html=coverage.out-ocoverage.html. Integrate coverage report in CI: create a coverage.out file, and upload analysis through third-party tools such as codecov or coveralls, for example, using curl--data-binary@coverage.o

How to set up golangci-lint for a project How to set up golangci-lint for a project Jul 12, 2025 am 03:06 AM

The installation steps of golangci-lint are: 1. Install using binary installation or Goinstall command; 2. Verify whether the installation is successful; the configuration methods include: 3. Create a .golangci.yml file to enable/disable linters, set an exclusion path, etc.; the integration methods are: 4. Add lint steps in CI/CD (such as GitHubActions) to ensure that lint checks are automatically run for each submission and PR.

How to avoid heap allocations in a performance-critical golang function How to avoid heap allocations in a performance-critical golang function Jul 13, 2025 am 03:06 AM

To reduce the heap allocation of critical path functions in Go, four methods can be taken: 1. Use stack variables to avoid escape; 2. Pre-allocate and reuse objects; 3. Avoid implicit escape writing; 4. Use tools to verify escape. Specifically, it includes avoiding returning local variable pointers, using value types to reduce escape, pre-allocate slice capacity, using sync.Pool to cache objects, avoiding closures to capture large structures, not assign interface types, and checking escape points through -gcflags=-m, thereby reducing GC pressure and improving performance.

See all articles