Go语言——sync.Map详解
1、前面,我们讲了map的用法以及原理 Golang中map的实现原理 ,但我们知道,map在并发读写的情况下是不安全。
2、M map[*Foo]int S []Foo }]bool 有一个字段不能做key、Foo就不允许做key,而这三个字段都不能。
3、测试场景在goroutines远大于GOMAXPROCS情况下,与非池化性能差异巨大。测试结果 可以看到同样使用*sync.pool,较大池大小的命中率较高,性能远高于空池。
4、包: golang.org/x/sync/singleflight作用:防击穿。瞬时的相同请求只调用一次,response 被所有相同请求共享。
go语言到底有什么好处
Go语言作为服务器编程语言,很适合处理日志、数据打包、虚拟机处理、文件系统、分布式系统、数据库代理等;网络编程方面。
对于高性能分布式系统领域而言,Go 语言无疑比大多数其它语言有着更高的开发效率。它提供了海量并行的支持,这对于游戏服务端的开发而言是再好不过了。到现在Go的开发已经是完全开放的,并且拥有一个活跃的社区。
Go语言融合了传统编译型语言的高效性和脚本语言的易用性和富于表达性,不仅提高了项目的开发速度,而且后期维护起来也非常轻松。编译器 当前有两个Go编译器分支,分别为官方编译器gc和gccgo。
go语言是不仅可以用来开发web,也可以用来开发底层,不仅如此,以太坊、超级账本都是基于go语言,还有go语言版本的btcd,对于这一点还是需要了解的。
GO语言的优势:可直接编译成机器码,不依赖其他库,glibc的版本有一定要求,部署就是扔一个文件上去就完成了。
Golang中sync.Map的实现原理
前面,我们讲了map的用法以及原理 Golang中map的实现原理 ,但我们知道,map在并发读写的情况下是不安全。
sync.Map是9才推荐的并发安全的map,除了互斥量以外,还运用了原子操作,所以在这之前,有必要了解下 Go语言——原子操作 go10\src\sync\map.go entry分为三种情况:从read中读取key,如果key存在就tryStore。
总体来说golang的map是hashmap,是使用数组+链表的形式实现的,使用拉链法消除hash冲突。
实现思路: (1) 当写map的某个key时,通过锁来保证其他goroutine不能再对其写或者读了。 (2) 当读map的某个key时,通过锁来保证其他的goroutine不能再对其写,但是可以读。
其实map是一种HashMap,表面上看它只有键值对结构,实际上在存储键值对的过程中涉及到了数组和链表。HashMap之所以高效,是因为其结合了顺序存储(数组)和链式存储(链表)两种存储结构。