0

0

Go语言中自定义类型切片存储指针的实践指南

花韻仙語

花韻仙語

发布时间:2025-11-23 20:42:06

|

730人浏览过

|

来源于php中文网

原创

Go语言中自定义类型切片存储指针的实践指南

本教程探讨了在go语言中如何正确地创建和管理包含自定义类型元素的切片,特别是当切片被定义为存储指针时遇到的常见问题。文章详细解释了将值类型赋值给指针切片时出现的“类型不匹配”错误,并提供了两种解决方案:使用地址运算符获取变量指针,或直接初始化结构体为指针。通过代码示例,帮助读者理解go语言中值类型和指针类型在切片操作中的关键区别,确保数据操作的正确性和高效性。

在Go语言中,自定义结构体(struct)和切片(slice)是构建复杂数据结构的基础。我们经常需要创建包含自定义类型元素的切片,例如一个存储“人员”信息的切片。然而,在处理值类型和指针类型时,Go语言有其独特的规则,理解这些规则对于避免常见的类型错误至关重要。

理解自定义类型与切片定义

首先,我们定义一个person结构体来表示一个人员,包含姓名和薪水字段。接着,我们定义一个people类型,它是一个person结构体指针的切片([]*person)。这意味着people类型的切片期望其每个元素都是一个指向person结构体的指针,而不是person结构体本身的值。

package main

import "fmt"

// 定义一个person结构体
type person struct {
    name   string
    salary float64
}

// 定义一个people类型,它是person结构体指针的切片
type people []*person

func main() {
    // 创建一个容量为10的people切片
    var data = make(people, 10)

    // 创建两个person结构体实例
    var a person
    var b person
    a.name = "John Smith"
    a.salary = 74000
    b.name = "Jane Smith"
    b.salary = 82000

    // 尝试将person值赋给*person切片元素
    // data[0] = a // 这里会发生错误
    // data[1] = b // 这里会发生错误

    fmt.Print(data)
}

在上述代码中,当我们尝试执行 data[0] = a 时,Go编译器会报告一个错误:“cannot use a (type person) as type person in assignment”(不能将类型person用作`person类型进行赋值)。这个错误明确指出,data切片期望的是*person类型(即person结构体的指针),而我们提供的是person类型(即person`结构体的值)。

解决方案一:使用地址运算符获取指针

解决这个问题的直接方法是,在将person结构体实例赋给people切片元素时,使用地址运算符&来获取该实例的内存地址,从而得到一个指向该实例的指针。

立即学习go语言免费学习笔记(深入)”;

慧中标AI标书
慧中标AI标书

慧中标AI标书是一款AI智能辅助写标书工具。

下载
package main

import "fmt"

type person struct {
    name   string
    salary float64
}

type people []*person

func main() {
    var data = make(people, 10)

    var a person
    var b person
    a.name = "John Smith"
    a.salary = 74000
    b.name = "Jane Smith"
    b.salary = 82000

    // 使用地址运算符&获取person实例的指针
    data[0] = &a
    data[1] = &b

    fmt.Print(data)
}

通过&a,我们得到了变量a的内存地址,它是一个*person类型的值。这样,data[0]就可以正确地存储这个指针了。这种方法适用于你已经有一个person值,并希望将其地址存储到指针切片中的情况。

解决方案二:直接初始化结构体为指针

另一种更简洁的方式是,在创建person结构体实例时就直接将其初始化为一个指针。Go语言提供了&StructName{}的语法来创建一个结构体并返回其指针。

package main

import "fmt"

type person struct {
    name   string
    salary float64
}

type people []*person

func main() {
    var data = make(people, 10)

    // 直接初始化person结构体为指针
    a := &person{} // 创建一个指向person结构体的指针
    b := &person{} // 创建另一个指向person结构体的指针

    a.name = "John Smith"
    a.salary = 74000
    b.name = "Jane Smith"
    b.salary = 82000

    // 直接将指针赋给切片元素
    data[0] = a
    data[1] = b

    fmt.Print(data)
}

在这种方法中,a和b本身就是*person类型(指向person结构体的指针),因此可以直接赋值给data切片的元素。这种方式在创建新的结构体实例并立即将其存储到指针切片中时,代码会更加简洁和直观。

重要注意事项与总结

  • 值类型 vs. 指针类型: Go语言严格区分值类型和指针类型。当切片被定义为存储*T(指向类型T的指针)时,它只能接受*T类型的值。尝试将T类型的值直接赋给它会导致编译错误
  • 选择存储值还是指针:
    • 如果切片定义为 []T (例如 []person),它将存储T类型的值的副本。每次向切片添加元素时,都会复制该值。
    • 如果切片定义为 []*T (例如 []*person),它将存储T类型的值的指针。这意味着切片中的元素都指向原始数据。当原始数据被修改时,切片中的所有指针都会反映这些修改。
  • 内存效率与修改行为: 对于大型结构体,存储指针 ([]*T) 可以减少内存复制的开销,提高性能。此外,当需要通过切片中的引用来修改原始结构体数据时,存储指针是唯一的选择。如果存储的是值 ([]T),对切片元素的修改只会影响副本,不会影响原始数据。
  • nil指针: 在[]*T切片中,元素可以为nil,表示不指向任何有效的T实例。这在某些场景下提供了灵活性,但也需要注意防止解引用nil指针导致运行时错误(panic)。

通过理解Go语言中值类型和指针类型的基本原理以及它们在切片操作中的体现,开发者可以更有效地管理数据结构,避免常见的类型错误,并编写出健壮、高效的Go程序。

相关专题

更多
java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1468

2023.10.24

Go语言中的运算符有哪些
Go语言中的运算符有哪些

Go语言中的运算符有:1、加法运算符;2、减法运算符;3、乘法运算符;4、除法运算符;5、取余运算符;6、比较运算符;7、位运算符;8、按位与运算符;9、按位或运算符;10、按位异或运算符等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

229

2024.02.23

php三元运算符用法
php三元运算符用法

本专题整合了php三元运算符相关教程,阅读专题下面的文章了解更多详细内容。

85

2025.10.17

golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

197

2025.06.09

golang结构体方法
golang结构体方法

本专题整合了golang结构体相关内容,请阅读专题下面的文章了解更多。

189

2025.07.04

treenode的用法
treenode的用法

​在计算机编程领域,TreeNode是一种常见的数据结构,通常用于构建树形结构。在不同的编程语言中,TreeNode可能有不同的实现方式和用法,通常用于表示树的节点信息。更多关于treenode相关问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

535

2023.12.01

C++ 高效算法与数据结构
C++ 高效算法与数据结构

本专题讲解 C++ 中常用算法与数据结构的实现与优化,涵盖排序算法(快速排序、归并排序)、查找算法、图算法、动态规划、贪心算法等,并结合实际案例分析如何选择最优算法来提高程序效率。通过深入理解数据结构(链表、树、堆、哈希表等),帮助开发者提升 在复杂应用中的算法设计与性能优化能力。

17

2025.12.22

深入理解算法:高效算法与数据结构专题
深入理解算法:高效算法与数据结构专题

本专题专注于算法与数据结构的核心概念,适合想深入理解并提升编程能力的开发者。专题内容包括常见数据结构的实现与应用,如数组、链表、栈、队列、哈希表、树、图等;以及高效的排序算法、搜索算法、动态规划等经典算法。通过详细的讲解与复杂度分析,帮助开发者不仅能熟练运用这些基础知识,还能在实际编程中优化性能,提高代码的执行效率。本专题适合准备面试的开发者,也适合希望提高算法思维的编程爱好者。

21

2026.01.06

Java编译相关教程合集
Java编译相关教程合集

本专题整合了Java编译相关教程,阅读专题下面的文章了解更多详细内容。

9

2026.01.21

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Go 教程
Go 教程

共32课时 | 4万人学习

Go语言实战之 GraphQL
Go语言实战之 GraphQL

共10课时 | 0.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号