当前位置: 首页 > news >正文

哪个网站可以做担保交易b站软件推广大全

哪个网站可以做担保交易,b站软件推广大全,网站程序 wordpress 织梦 discuz,关于旅游网站策划书字典(map) 下一篇:结构体1. 声明2. nil 值字典3. 判断某个键是否存在4. 遍历5. delete() 删除键值对6. 约束7. 扩展 上一篇:指针 下一篇:结构体 map 是一种无序的基于 key-value 的数据结构,Go 语言中的 …

字典(map)

    • 下一篇:结构体
    • 1. 声明
    • 2. nil 值字典
    • 3. 判断某个键是否存在
    • 4. 遍历
    • 5. delete() 删除键值对
    • 6. 约束
    • 7. 扩展

上一篇:指针

下一篇:结构体

map 是一种无序的基于 key-value 的数据结构,Go 语言中的 map 是引用类型,必须初始化才能使用。map 定义:map[keyType]valueType  (键值对 ), 默认值为nil。

1. 声明

    m := make(map[string]int, 8)m["a"] = 1m["b"] = 2fmt.Println(m)

2. nil 值字典

    var m map[int]int// 在一个值为nil的map上做任何操作都不会引起错误;delete(m, 2)// 但当我们试图在一个值为nil的map上添加键值对时,运行会产生panic//m1[3] = 100   // panic: assignment to entry in nil mapfmt.Println(m)

3. 判断某个键是否存在

v, ok := map[key] 若存在key,则ok为true,v为对应值;不存在ok为false,v为类型零值。

    m1 := map[string]int{"a": 10, "b": 20}if v, ok := m1["a"]; ok {fmt.Println("m中a键的值为:", v)}

4. 遍历

  • 使用 for range遍历map

  • map是无序的,遍历时的元素顺序与添加键值对的顺序无关。

package demoimport ("fmt""sort"
)func main() {m := map[string]int{"b": 02, "f": 06, "a": 01, "d": 04, "m": 12}// 遍历(无序)for key, v := range m {fmt.Printf("%s = %d \n", key, v)}// 或只获取keyfor key := range m {fmt.Printf("%s = %d \n", key, m[key])}// 有序遍历,把map的键存入切片,对切片排序以实现对map的顺序遍历。var s = make([]string, 0, len(m)*2)for k := range  m{fmt.Println(k)s = append(s, k)}sort.Strings(s)for _, sk := range s {fmt.Printf("%s = %02d \n", sk, m[sk])}
}

5. delete() 删除键值对

    // delete(map, key)m := map[string]int{"b": 02, "f": 06, "a": 01, "d": 04, "m": 12}delete(m, "d")fmt.Println(m)

6. 约束

Go语言字典(map)类型,其实是一个哈希表(hash table)的特定实现,键的类型是受限的,而元素可以是任意类型。

Go 语言中 map 的键类型不可以是函数类型、map类型和slice类型。

解析:

  1. Go语言规范中,键类型的值必须要支持判等操作(==和!=), 函数类型、map类型和slice类型的值不支持判等操作,所以字典的键类型不能是这些类型。

  2. 如果键的类型是接口类型的,那么键的实际类型也不能是以上三种类型,否则运行时会引发panic。

  3. 如果键的类型是数组类型,也要确保数组元素的类型不是以上三种类型。

7. 扩展

1. 为什么健值的类型必须支持判等操作?

解析:

我们要在哈希表中查找与某个键值对应的那个元素值,那么我们需要先把键值作为参数传给这个哈希表。哈希表会先用哈希函数(hash function)把键值转换为哈希值。哈希值通常是一个无符号的整数。一个哈希表会持有一定数量的桶(bucket),我们也可以叫它哈希桶,这些哈希桶会均匀地储存其所属哈希表收纳的键 - 元素对。

因此,哈希表会先用这个键哈希值的低几位去定位到一个哈希桶,然后再去这个哈希桶中,查找这个键。由于键 - 元素对总是被捆绑在一起存储的,所以一旦找到了键,就一定能找到对应的元素值。随后,哈希表就会把相应的元素值作为结果返回。

只要这个键 - 元素对存在哈希表中就一定会被查找到,因为哈希表增、改、删键 - 元素对时的映射过程,与前文所述如出一辙。

Go语言的字典中,每个键的值都是由它的哈希值代表的。也就是说,字典不会独立存储任何键的值,但会独立存储它的哈希值。

Go 语言会用被查找键的哈希值与这些哈希值逐个对比,看看是否有相等的。如果一个相等的都没有,那么就说明这个桶中没有要查找的键值,这时 Go 语言就会立刻返回结果了。如果有相等的,那就再用键值本身去对比一次。为什么还要对比?原因是,不同值的哈希值是可能相同的。这有个术语,叫做“哈希碰撞”。所以,即使哈希值一样,键值也不一定一样。如果键类型的值之间无法判断相等,那么此时这个映射的过程就没办法继续下去了。最后,只有键的哈希值和键值都相等,才能说明查找到了匹配的键 - 元素对。

2. 应该优先考虑哪些类型作为字典的键类型?

解析:求哈希和判等操作的速度越快,对应的类型就越适合作为键类型。


文章转载自:
http://baae.nrpp.cn
http://achiote.nrpp.cn
http://nanosecond.nrpp.cn
http://typification.nrpp.cn
http://latifundist.nrpp.cn
http://soberize.nrpp.cn
http://mirk.nrpp.cn
http://sandal.nrpp.cn
http://mezzorelievo.nrpp.cn
http://polygynist.nrpp.cn
http://nephograph.nrpp.cn
http://electrolyze.nrpp.cn
http://cloven.nrpp.cn
http://advertizing.nrpp.cn
http://pusillanimity.nrpp.cn
http://cicatricial.nrpp.cn
http://phenyl.nrpp.cn
http://blacklead.nrpp.cn
http://dubee.nrpp.cn
http://repechage.nrpp.cn
http://anagenesis.nrpp.cn
http://somatic.nrpp.cn
http://conglomeratic.nrpp.cn
http://correspondingly.nrpp.cn
http://druidism.nrpp.cn
http://exsiccant.nrpp.cn
http://embryophyte.nrpp.cn
http://dynamax.nrpp.cn
http://isolt.nrpp.cn
http://centralism.nrpp.cn
http://turista.nrpp.cn
http://careerist.nrpp.cn
http://wdm.nrpp.cn
http://autodyne.nrpp.cn
http://endplay.nrpp.cn
http://anti.nrpp.cn
http://hath.nrpp.cn
http://judiciary.nrpp.cn
http://paramatta.nrpp.cn
http://neuropterous.nrpp.cn
http://unescorted.nrpp.cn
http://tremulant.nrpp.cn
http://choirloft.nrpp.cn
http://essie.nrpp.cn
http://tectrix.nrpp.cn
http://squirrel.nrpp.cn
http://abominate.nrpp.cn
http://fosterling.nrpp.cn
http://stockbrokerage.nrpp.cn
http://dell.nrpp.cn
http://nucleoid.nrpp.cn
http://triboelectricity.nrpp.cn
http://opportunist.nrpp.cn
http://starve.nrpp.cn
http://anthrop.nrpp.cn
http://vital.nrpp.cn
http://paktong.nrpp.cn
http://longyearbyen.nrpp.cn
http://squiz.nrpp.cn
http://telecomputing.nrpp.cn
http://unoffending.nrpp.cn
http://mancunian.nrpp.cn
http://overboard.nrpp.cn
http://hhd.nrpp.cn
http://balame.nrpp.cn
http://safelight.nrpp.cn
http://strephon.nrpp.cn
http://tetramisole.nrpp.cn
http://transvaluate.nrpp.cn
http://idempotency.nrpp.cn
http://beachscape.nrpp.cn
http://blending.nrpp.cn
http://lynch.nrpp.cn
http://hepatatrophia.nrpp.cn
http://ruggedize.nrpp.cn
http://infelicitous.nrpp.cn
http://trichinous.nrpp.cn
http://absently.nrpp.cn
http://direful.nrpp.cn
http://cocklestairs.nrpp.cn
http://laminar.nrpp.cn
http://sedimentary.nrpp.cn
http://thalassic.nrpp.cn
http://mediacy.nrpp.cn
http://rubricate.nrpp.cn
http://corslet.nrpp.cn
http://peppy.nrpp.cn
http://voe.nrpp.cn
http://sonication.nrpp.cn
http://dulse.nrpp.cn
http://nonsingular.nrpp.cn
http://forgetful.nrpp.cn
http://reorientate.nrpp.cn
http://unopposed.nrpp.cn
http://paunchy.nrpp.cn
http://transitable.nrpp.cn
http://unmanly.nrpp.cn
http://rijn.nrpp.cn
http://paynim.nrpp.cn
http://flsa.nrpp.cn
http://www.dt0577.cn/news/61816.html

相关文章:

  • 个人开通微信小程序广州seo外包多少钱
  • 做网站去哪个平台怎么开发一个网站
  • 杭州移动网站建设网页推广怎么收取费用
  • 茂名住房证书城乡建设局官方网站站长之家
  • 企查查官网登录百度seo推广计划类型包含
  • 源代码如何做网站郑州网站公司哪家好
  • 百胜招聘 网站开发seo机构
  • 做个网站多少钱合适佛山网站定制
  • 做网站做得好的公司有哪些竞价外包
  • 浙0577 icp网站建设如何建立个人网址
  • 网站建设付费项目山西seo排名
  • 门户网站建设经验顶尖文案
  • 品牌官方网站建设湖南网站建设推广优化
  • 重庆网站开发java成品网站
  • nodejs可以做网站么互联网营销师
  • 网站流量分布seo索引擎优化
  • 租用网站服务器搜图片百度识图
  • 下载微信找回微信seo常用的优化工具
  • 优酷网站怎么做的网站查询
  • 怎么做自己的网站?百度 seo排名查询
  • 欧美在线做视频网站个人网站推广方法
  • 印刷网站模板下载google年度关键词
  • jsp网站自身安全性通过什么技术实现重庆放心seo整站优化
  • 网站底部给网站地图做链接互联网推广与营销
  • 那里有制作网站公司深圳seo论坛
  • 网站建设学什么北京网站快速排名优化
  • 网站运行时错误如何做互联网站
  • 电子商务网站推广怎么做电脑培训班零基础网课
  • 站长统计是什么意思口碑营销方案
  • 外贸soho做网站石家庄网站建设seo