如何在Golang中实现地图的线程安全地图?
我正在研究一个多线程模块,并且需要在Golang中实现MAP的地图 - MAP [ofter] Map [innin]*some_struct
。外部键(MAP [OUTAR])将通过多个线程(Goroutines)访问,以将键添加到内映射中。我怀疑是否可以同时将密钥添加到内映射中,以获取一个公共的外键-MAP [outer]。它是安全的,并且同步是一个更好的选择吗? 另外,外部键[外部]和外键总数在运行时已知,因此无法事先定义锁。
为了更好地理解问题陈述,我们可以添加有关不同城市的信息的示例。我们可以按各州对城市进行分组。每个线程代表一个城市。要添加有关城市的信息,第一个线程需要检查外键 - 状态,(映射[state]),然后每个线程只需将信息添加到map [state] [state] [city] =& soly_struct {x:y ,y:z}
。
我读了很少的文章,发现同步法适合并发地图操作,这些操作是原子进行的。但是在文档中,提到的用例之一是 - 当多个goroutines读取,写入和覆盖键的条目 时。
如果有人可以为此问题陈述建议线程安全方法,将会有所帮助。
I am working on a multi-threaded module and need to implement map of map in golang - map[outer]map[inner]*some_struct
. The outer key(map[outer]) will be accessed by multiple threads(goroutines) to add key to inner map. I have a doubt if multiple threads can concurrently add keys to inner map, for a common outer key - map[outer]. Is it thread safe and is sync.Map a better option ?
Also outer key- map[outer] and total number of outer keys are known at runtime so can't define locks beforehand.
To better understand the problem statement, we can take example of add information about different cities. We can group cities by states. Each thread represents a city. To add info about a city, first thread needs to check outer key - state,(map[state]) and then each thread will simply add info to map[state][city] = &some_struct{x:y,y:z}
.
I have read few articles and found out sync.Map is suitable for concurrent map operations and these operations are performed atomically. But in documentation one of the use-case mentioned was - when multiple goroutines read, write, and overwrite entries for disjoint sets of keys.
It will be helpful if someone can suggest thread-safe approach for this problem statement.
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
您必须用oo术语
来实用该地图的地图?
地图状态,城市有意义。但是,您想做什么样的操作?
写和阅读,并发?为什么?
您想在所有城市上迭代吗?您需要删除城市/州吗?
以下接口
想象一下我们可以考虑使用此接口的
您可以创建一个地图[复合密钥] struct,例如
状态:city
to简化。
想法那样拆分:
You must thing in OO terms
What do you want to represent as map of map?
Map state, city make some sense. However what kind of operations do you want to do?
Write and Read, concurrent? Why?
Do you want to iterate over all cities? Do you need to delete cities/states?
Imagine the following interface
With this interface we can consider:
you can create a map[ composite key ] struct like
state:city
tosimplify.
Ideas: