【golang】Go实现set类型
如何实现set
Go中是不提供Set类型的,Set是一个集合,其本质就是一个List,只是List里的元素不能重复。
Go提供了map类型,但是我们知道,map类型的key是不能重复的,因此,我们可以利用这一点,来实现一个set。那value呢?value我们可以用一个常量来代替,比如一个空结构体,实际上空结构体不占任何内存,使用空结构体,能够帮我们节省内存空间,提高性能
下面看看两种结构体的声明方法
type Empty struct { }
func main(){
empty := new(Empty)
fmt.Println(unsafe.Sizeof(empty)) //