golang 类似set使用

本文介绍了如何在Golang中创建类似集(Set)的数据结构,通过代码示例展示其用法,帮助理解如何实现集合操作如添加元素、检查元素存在及删除元素等功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

     本文借鉴一篇博客,原文链接: http://www.jb51.net/article/56828.htm


    实现向python或者javaScript的set功能,golang中本身没有这个功能,现在可以自己写类似set的功能

    代码如下:

     

package main
import(
  "fmt"
  "sync"
)
type Set struct {
  m map[int]bool
  sync.RWMutex
}
func New() *Set {        //创建一个set对象
  return &Set{
    m: map[int]bool{},
  }
}
func (s *Set) Add(item int) {     // 向集合中添加 item 元素
  s.Lock()
  defer s.Unlock()
  s.m[item] = true
}
func (s *Set) Remove(item int) {      // 移除集合 item 元素
  s.Lock()
  s.Unlock()
  delete(s.m, item)
}
func (s *Set) Has(item int) bool {         // 判断集合是否存在 item 元素
  s.RLock()
  defer s.RUnlock()
  _, ok := s.m[item]
  return ok
}
func (s *Set) Len() int {           // 获取集合的长度[元素个数]
  return len(s.List())
}
func (s *Set) Clear() {             // 清空集合所有元素
  s.Lock
  defer s.Unlock()
  s.m = map[int]bool{}
}
func (s *Set) IsEmpty() bool {        // 判断集合是否为空
  if s.Len() == 0 {
    return true
  }
  return false
}
func (s *Set) List() []int {             // 集合列表
  s.RLock()
  defer s.RUnlock()
  list := []int{}
  for item := range s.m {
    list = append(list, item)
  }
  return list
}
func main() {
  // 初始化
  s := New()
  
  s.Add(1)
  s.Add(1)
  s.Add(2)
  s.Clear()
  if s.IsEmpty() {
    fmt.Println("0 item")
  }
  
  s.Add(1)
  s.Add(2)
  s.Add(3)
  
  if s.Has(2) {
    fmt.Println("2 does exist")
  }
  
  s.Remove(2)
  s.Remove(3)
  fmt.Println("list of all items", S.List())
}

     以此共勉...
    
    



     

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值