文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

怎么在golang中利用结构体嵌套的切片数组

2023-06-14 22:08

关注

本篇文章为大家展示了怎么在golang中利用结构体嵌套的切片数组,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

什么是golang

golang 是Google开发的一种静态强类型、编译型、并发型,并具有垃圾回收功能的编程语言,其语法与 C语言相近,但并不包括如枚举、异常处理、继承、泛型、断言、虚函数等功能。

package mainimport ( "fmt")type XCDataStu struct { Id   int    `json:"id"   xorm:"id"` Name string `json:"name"  xorm:"name"`}type XCDataStu1 struct { Id             int    `json:"id" xorm:"id"` Str1           string `json:"str1" xorm:"str1"` Db1            string `json:"db1" xorm:"db1"` Device_type    string `json:"Device_type" xorm:"Device_type"` DeviceTypeName string `json:"DeviceTypeName"`}type XCDataStuAll struct {//结构体嵌套 XCDataStuinall  XCDataStu XCDataStu1inall XCDataStu1}func main() { xcData := []XCDataStu{  XCDataStu{Id: 758, Name: "David758"},  XCDataStu{Id: 759, Name: "David759"}, } xcdataall := make([]XCDataStuAll, len(xcData))  fmt.Println(len(xcData)) fmt.Println(xcData[0]) fmt.Println(xcData[1]) i := 0 for ; i < 2; i++ {  xcdataall[i].XCDataStuinall.Id = xcData[i].Id  xcdataall[i].XCDataStuinall.Name = xcData[i].Name } fmt.Println(xcdataall)}

结构体切片:

可以直接声明时初始化,如程序中的1

可以用make,但是必须给定长度,否则不能使用下标进行赋值。

如程序中的2

 var xcdataall []XCDataStuAll for ; i < 2; i++ {  xcdataall[i].XCDataStuinall.Id = xcData[i].Id  xcdataall[i].XCDataStuinall.Name = xcData[i].Name }

程序编译没错,但是最后运行后会出现panic。。。

panic: runtime error: index out of range

补充:go遍历结构体(struct)字段对应的值,切片(slice),字典(map)

一、遍历结构体字段:

eg1:

package mainimport (    "fmt"    "reflect")type person struct {    name string    age  int}func main() {    v := reflect.ValueOf(person{"steve", 30})    count := v.NumField()    for i := 0; i < count; i++ {        f := v.Field(i)        switch f.Kind() {        case reflect.String:            fmt.Println(f.String())        case reflect.Int:            fmt.Println(f.Int())        }    }}

输出结果:

steve

30

eg2:

package mainimport (    "fmt"    "reflect")type NotknownType struct {    s1, s2, s3 string}var secret interface{} = NotknownType{"Ada", "Go", "Oberon"}func main() {    value := reflect.ValueOf(secret)    for i := 0; i < value.NumField(); i++ {        fmt.Printf("Field %d: %v\n", i, value.Field(i))    }}

输出结果:

Field 0: Ada

Field 1: Go

Field 2: Oberon

二、遍历切片:

for range 结构

package mainimport (    "fmt")func main(){    slice := []string{"hello","world","hello","everyone!"}    for k,val:=range slice{        fmt.Printf("slice %d is :%s\n",k,val )    }}

输出结果:

slice 0 is :hello

slice 1 is :world

slice 2 is :hello

slice 3 is :everyone!

三、遍历map:

package mainimport (    "fmt")func main() {    m := make(map[string]string)    m["1"] = "hello"    m["2"] = "world"    m["3"] = "go"    m["4"] = "is"    m["5"] = "cool"    fmt.Printf("The corresponding relationship between key and value is:\n")    for key, val := range m {        fmt.Printf("%v===>%v\n", key, val)    }}

输出结果:

The corresponding relationship between key and value is:

1===>hello

2===>world

3===>go

4===>is

5===>cool

但是还有一个问题,上面的程序不做改动运行第二次,结果顺序就会改变,因为map遍历出来结果是无序的,这不好控制,也不利于业务逻辑;当业务依赖key次序时,需要引入“sort”包来解决随机化问题

代码如下:

package mainimport (    "fmt"    "sort")func main() {    m := make(map[string]string)    m["1"] = "hello"    m["2"] = "world"    m["3"] = "go"    m["4"] = "is"    m["5"] = "cool"    sorted_keys := make([]string, 0)    for k, _ := range m {        sorted_keys = append(sorted_keys, k)    }    sort.Strings(sorted_keys)    for _, k := range sorted_keys {        fmt.Printf("%v=====>%v\n", k, m[k])    }}

输出结果是:

1=====>hello

2=====>world

3=====>go

4=====>is

5=====>cool

上述内容就是怎么在golang中利用结构体嵌套的切片数组,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注编程网行业资讯频道。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     801人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     348人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     311人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     432人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     220人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯