go channel的设置长度思想和循环队列

Posted myuniverse

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了go channel的设置长度思想和循环队列相关的知识,希望对你有一定的参考价值。

channel的长度决定方法

  • 根据上下游的速度比例成线性关系
  • 根据CPU的性能进行设置
  • 根据业务需求

go手写创建循环队列(链表的形式实现)

  • 循环队列示例图

技术图片

package main

import(
    "fmt"
    "strconv"
)

// 队列指针
type Qpointer struct{
    Length int
    Head *Data
    Tail *Data 
}

// 数据
type Data struct{
    InData string
    Tailer *Data
}

// 创建数据
func createData(data string)*Data{
    return &Data{InData:data}
}

// 根据长度创建相对应长度的链表
func createList(length int)*Data{
    if length<=0{
        return nil
    }
    head := createData(strconv.Itoa(length))
    // tmp相当连接器
    tmp := head
    for i:=1;i<length;i++{
        data := createData(strconv.Itoa(i))
        tmp.Tailer = data
        if i==length-1{
            data.Tailer = head
            break
        }
        tmp = data
    }
    return head
}

// 创建循环队列
func createQueue(length int)*Qpointer{
    // 根据长度获取链表
    list := createList(length)
    if list==nil{
        fmt.Println("创建链表失败")
        return nil
    }
    q := &Qpointer{Length:length,Head:list,Tail:list}
    return q    
}

// 循环队列的读取
func(q *Qpointer)readQ(){
    tmp := q.Tail
    for{
        fmt.Println(tmp.InData)
        tmp = tmp.Tailer
        if tmp==q.Head{
            break
        }
    }
    fmt.Println("读取成功")
}


func main(){
    var length int
    fmt.Println("请输入想要制作链表的长度")
    fmt.Scan(&length)
    q := createQueue(length)
    if q==nil{
        fmt.Println("创建循环队列失败")
        return
    }
    q.readQ()
}

以上是关于go channel的设置长度思想和循环队列的主要内容,如果未能解决你的问题,请参考以下文章

Go语言channel

Go语言channel

Go语言channel

channel原来就是个环形队列

GO语言的并发Concurrency:Goroutine与通信机制Channel

golang - channel