Table of Contents
Explain the difference between make and new in Go. When would you use each?
What types of data structures are best initialized with 'make' in Go?
How does memory allocation differ between 'make' and 'new' in Go?
In what scenarios might 'new' be more appropriate than 'make' in Go?
Home Backend Development Golang Explain the difference between make and new in Go. When would you use each?

Explain the difference between make and new in Go. When would you use each?

Mar 26, 2025 pm 01:39 PM

Explain the difference between make and new in Go. When would you use each?

In Go, make and new are both used for memory allocation, but they serve different purposes and are used with different types.

  • new: The new function allocates memory for a given type and returns a pointer to that memory. The memory is initialized to zero values for that type. new is used with any type, including built-in types, structs, and custom types. It returns a pointer of type *T to newly allocated zeroed storage for a new item of type T. For example:

    p := new(int)   // p, of type *int, points to an unnamed int variable
    fmt.Println(*p) // prints 0
    Copy after login

    You would use new when you need a pointer to a zeroed value of a type, particularly when you're working with structs or other composite types where you want to ensure all fields are initialized to their zero values.

  • make: The make function is used only with the built-in types slice, map, and channel. Unlike new, make initializes these types to non-zero values. It returns an initialized (not zeroed) value of type T (not *T), which is ready to use. For example:

    s := make([]int, 5) // s is a slice of ints, length 5, capacity 5
    m := make(map[string]int) // m is a map of strings to ints
    c := make(chan int) // c is a channel of ints
    Copy after login

    You would use make when you're initializing slices, maps, or channels. These types need special initialization and are not merely allocated with zero values.

What types of data structures are best initialized with 'make' in Go?

In Go, the make function is specifically designed for initializing the following three data structures:

  • Slices: Slices are dynamic arrays that can grow or shrink in size. When you use make with a slice, you specify the length and optionally the capacity. This initializes the slice with zero values for its elements.

    mySlice := make([]int, 5, 10) // length 5, capacity 10
    Copy after login
  • Maps: Maps are key-value pairs where keys are unique. Using make with a map initializes an empty map ready to store key-value pairs.

    myMap := make(map[string]int)
    Copy after login
  • Channels: Channels are the conduits through which you can send and receive values with the channel operator <-. Using make with a channel initializes an empty channel that can be used for communication between goroutines.

    myChannel := make(chan int)
    Copy after login

How does memory allocation differ between 'make' and 'new' in Go?

Memory allocation in Go differs between make and new in the following ways:

  • new: When you use new, Go allocates memory for the type you specify and returns a pointer to that memory. The memory is initialized to the zero value for the specified type. new essentially performs a simple memory allocation without any additional initialization beyond setting zero values. It is generic and works with any type.

    p := new(int) // allocates memory and returns a pointer to zeroed int
    Copy after login
  • make: When you use make, Go not only allocates memory but also initializes the data structure. For slices, make allocates an underlying array of the specified length and capacity, and the slice is initialized with zero values. For maps and channels, make performs necessary internal initialization to make them ready to use. make only works with slices, maps, and channels.

    s := make([]int, 5) // allocates memory for a slice and initializes it
    Copy after login

In summary, new allocates memory and returns a pointer to zeroed storage, whereas make allocates memory and initializes the specified data structure (slice, map, or channel) to a ready-to-use state.

In what scenarios might 'new' be more appropriate than 'make' in Go?

new might be more appropriate than make in the following scenarios:

  • When working with custom types or structs: If you're defining a custom type or struct and need a pointer to a zeroed instance of that type, new is the appropriate choice. This is often useful for initializing objects before you fill in their fields.

    type Person struct {
      Name string
      Age  int
    }
    
    p := new(Person) // p is of type *Person, points to zeroed Person struct
    p.Name = "Alice"
    p.Age = 30
    Copy after login
  • When you need a pointer to any type: If you need a pointer to a basic type like int, float64, etc., or to a custom type where you want the zero value, new is suitable. This can be useful in scenarios where you're working with pointers directly.

    pi := new(int) // pi is of type *int, points to zeroed int
    *pi = 42
    Copy after login
  • For efficient zero-value initialization: When you want to efficiently allocate and zero-initialize memory for a type without the overhead of additional setup that make performs for slices, maps, and channels, new is more appropriate.

    zeroInt := new(int) // Efficient way to get a zeroed int pointer
    Copy after login
  • For compatibility with older code or libraries: In some cases, older Go code or libraries might expect pointers to types, and new can be used to satisfy these expectations.

In summary, new is more appropriate when you need a pointer to a zeroed value of any type, especially when working with custom types, structs, or basic types where you want to initialize to zero values before further manipulation.

The above is the detailed content of Explain the difference between make and new in Go. When would you use each?. 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

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.

Undress AI Tool

Undress AI Tool

Undress images for free

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 Article

Roblox: Bubble Gum Simulator Infinity - How To Get And Use Royal Keys
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Nordhold: Fusion System, Explained
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Mandragora: Whispers Of The Witch Tree - How To Unlock The Grappling Hook
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Clair Obscur: Expedition 33 - How To Get Perfect Chroma Catalysts
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌

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

Java Tutorial
1677
14
PHP Tutorial
1278
29
C# Tutorial
1257
24
Golang vs. Python: Performance and Scalability Golang vs. Python: Performance and Scalability Apr 19, 2025 am 12:18 AM

Golang is better than Python in terms of performance and scalability. 1) Golang's compilation-type characteristics and efficient concurrency model make it perform well in high concurrency scenarios. 2) Python, as an interpreted language, executes slowly, but can optimize performance through tools such as Cython.

Golang and C  : Concurrency vs. Raw Speed Golang and C : Concurrency vs. Raw Speed Apr 21, 2025 am 12:16 AM

Golang is better than C in concurrency, while C is better than Golang in raw speed. 1) Golang achieves efficient concurrency through goroutine and channel, which is suitable for handling a large number of concurrent tasks. 2)C Through compiler optimization and standard library, it provides high performance close to hardware, suitable for applications that require extreme optimization.

Getting Started with Go: A Beginner's Guide Getting Started with Go: A Beginner's Guide Apr 26, 2025 am 12:21 AM

Goisidealforbeginnersandsuitableforcloudandnetworkservicesduetoitssimplicity,efficiency,andconcurrencyfeatures.1)InstallGofromtheofficialwebsiteandverifywith'goversion'.2)Createandrunyourfirstprogramwith'gorunhello.go'.3)Exploreconcurrencyusinggorout

Golang vs. C  : Performance and Speed Comparison Golang vs. C : Performance and Speed Comparison Apr 21, 2025 am 12:13 AM

Golang is suitable for rapid development and concurrent scenarios, and C is suitable for scenarios where extreme performance and low-level control are required. 1) Golang improves performance through garbage collection and concurrency mechanisms, and is suitable for high-concurrency Web service development. 2) C achieves the ultimate performance through manual memory management and compiler optimization, and is suitable for embedded system development.

Golang vs. Python: Key Differences and Similarities Golang vs. Python: Key Differences and Similarities Apr 17, 2025 am 12:15 AM

Golang and Python each have their own advantages: Golang is suitable for high performance and concurrent programming, while Python is suitable for data science and web development. Golang is known for its concurrency model and efficient performance, while Python is known for its concise syntax and rich library ecosystem.

Golang and C  : The Trade-offs in Performance Golang and C : The Trade-offs in Performance Apr 17, 2025 am 12:18 AM

The performance differences between Golang and C are mainly reflected in memory management, compilation optimization and runtime efficiency. 1) Golang's garbage collection mechanism is convenient but may affect performance, 2) C's manual memory management and compiler optimization are more efficient in recursive computing.

The Performance Race: Golang vs. C The Performance Race: Golang vs. C Apr 16, 2025 am 12:07 AM

Golang and C each have their own advantages in performance competitions: 1) Golang is suitable for high concurrency and rapid development, and 2) C provides higher performance and fine-grained control. The selection should be based on project requirements and team technology stack.

Golang vs. Python: The Pros and Cons Golang vs. Python: The Pros and Cons Apr 21, 2025 am 12:17 AM

Golangisidealforbuildingscalablesystemsduetoitsefficiencyandconcurrency,whilePythonexcelsinquickscriptinganddataanalysisduetoitssimplicityandvastecosystem.Golang'sdesignencouragesclean,readablecodeanditsgoroutinesenableefficientconcurrentoperations,t

See all articles