码迷,mamicode.com
首页 > 编程语言 > 详细

go语言从零学起(二)--list结构基本用法

时间:2016-12-07 20:04:26      阅读:169      评论:0      收藏:0      [点我收藏+]

标签:nil   go标准库   ext   i++   语言   containe   输出   转义   log   

list,go标准库双向链表结构

定义:

a := list.New()

用法示例:

package main

import (
    "container/list"
    "fmt"
)

func main() {
    l := list.New()

    l.PushBack(1) //插入链表的最后一个位置
    l.PushBack(2)
    l.PushBack(3)
    l.PushFront(4) //插入链表的第一个位置

    i := 1
    for e := l.Front(); e != nil; e = e.Next() {
        fmt.Printf("元素%d:%d\n", i, e.Value)
    }
}

输出结果:

元素1:4
元素2:1
元素3:2
元素4:3

list中元素为struct时,获取元素每项的方式稍微有些区别,示例如下:

package main

import (
    "container/list"
    "fmt"
)

type User struct {
    id   int
    name string
}

func main() {

    l := list.New()

    item1 := User{id: 101, name: "name1"}
    item2 := User{id: 102, name: "name2"}
    l.PushBack(item1)
    l.PushBack(item2)

    i := 1
    for e := l.Front(); e != nil; e = e.Next() {
        fmt.Printf("元素%d: id:%d, name:%s\n", i, e.Value.(User).id, e.Value.(User).name) //先转义后使用
        i++
    }
}

输出为:

元素1: id:101, name:name1
元素2: id:102, name:name2

 

go语言从零学起(二)--list结构基本用法

标签:nil   go标准库   ext   i++   语言   containe   输出   转义   log   

原文地址:http://www.cnblogs.com/cornor/p/6142249.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!