大佬教程收集整理的这篇文章主要介绍了自定义堆栈Stack,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
测试用例: https://github.com/panyingyun/gostudy/blob/master/testStack.go
package main import ( "fmt" "github.com/panyingyun/gostudy/stacker" ) func main() { a := stacker.NewStack(2) a.Push("Google") a.Push(100) a.Push([]int{1,2,3}) fmt.Println(a) fmt.Println(a.Len()) fmt.Println(a.Cap()) for { item,err := a.Pop() if err != nil { fmt.Println(err) break } fmt.Println(item) } }
stack定义: https://github.com/panyingyun/gostudy/blob/master/stacker/stack.go
package stacker import ( "errors" ) type Stack struct { st []interface{} len int cap int } func NewStack(cap int) *Stack { st := make([]interface{},cap) return &Stack{st,cap} } func (s *Stack) Len() int { return s.len } func (s *Stack) Cap() int { return s.cap } func (s *Stack) Push(p interface{}) { s.st = append(s.st,p) s.len = len(s.st) s.cap = cap(s.st) } func (s *Stack) Pop() (interface{},error) { if s.len == 0 { return nil,errors.New("Can't pop an empty stack") } s.len -= 1 out := s.st[s.len] s.st = s.st[:s.len] return out,nil }
以上是大佬教程为你收集整理的自定义堆栈Stack全部内容,希望文章能够帮你解决自定义堆栈Stack所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。