Go语言基础案列学习 -- 实现简单的字典序列结构

package main

import (
	"encoding/json"
	"fmt"
)

// 自己实现一个map结构
type Dictionary struct {
	data map[interface{}]interface{}
}
//map的get方法
func (d *Dictionary) Get(key interface{}) interface{}{
	return d.data[key]
}
//map的set方法
func (d *Dictionary) Set(key, value interface{})  {
	d.data[key] = value
}

//map的遍历 遍历所有的键值关联数据 在不符合要求是直接退出循环
func (d *Dictionary) Visit(callback func(k, v interface{}) bool)  {
	if callback == nil{
		return
	}
	for k, v := range d.data{
		if !callback(k, v){
			return
		}
	}
}
//新家一个字典
func NewDictionary()  *Dictionary{
	d := &Dictionary{}
	d.Clear()
	return d
}
//go语言没有复位内部元素的操作,需要复位的时候使用make创建新的实例 go语言的垃圾回收机制是并行的 不用担心map的清楚效率的问题
func (d *Dictionary) Clear()  {
	d.data = make(map[interface{}]interface{})
}

func main()  {
	dict := NewDictionary()
	dict.Set("java", 60)
	dict.Set("mysql", 36)
	dict.Set("redis", 24)
	s := dict.Get("java")
	fmt.Println(s)
	dict.Visit(func(k, v interface{}) bool {
		if v.(int) > 40 {
			fmt.Println(k, "很贵")
			return true
		}
		fmt.Println(k, "很便宜")
		return true
	})

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值