返回顶部
首页 > 资讯 > 后端开发 > GO >golang 中带有切片的并发映射
  • 833
分享到

golang 中带有切片的并发映射

golang开发 2024-02-11 10:02:33 833人浏览 泡泡鱼
摘要

PHP小编香蕉带来了一篇精彩的文章,讲述了golang中切片的并发映射。在这篇文章中,我们将了解如何在并发环境中使用切片进行映射操作,并解释了为什么切片在并发编程中非常有用。通过使用G

PHP小编香蕉带来了一篇精彩的文章,讲述了golang中切片的并发映射。在这篇文章中,我们将了解如何在并发环境中使用切片进行映射操作,并解释了为什么切片在并发编程中非常有用。通过使用Golang的并发机制,我们可以在多个goroutine中同时访问和修改切片,从而提高程序的性能和效率。无论你是初学者还是有经验的golang开发者,这篇文章都将给你带来有价值的知识和实践技巧。让我们一起来探索golang中带有切片的并发映射吧!

问题内容

在该领域的一位开发人员几个月前离开后,我一直在尝试解决并发问题,但我找不到解决此问题的适当方法。

对于上下文,我们将客户数据加载到如下结构中:

[ 键 ] -> { 值 }

[客户特定哈希] -> {数据点/文件切片}

示例 - 格式确实很糟糕,抱歉:

[a60d849ad97bfb833e1096941] 
-> 
{ 
 { StartDate: '01-02-2022', EndDate: '28-02-2022', DataFrames: [1598,921578,12981,21749,192578...]},
 { StartDate: '01-03-2022', EndDate: '28-03-2022', DataFrames: [1234,1567,6781,126978...]},
}

以上是因为我们有 100,000 名客户,并且每天晚上都会启动一个流程,根据每个客户的哈希值(或实际上是一个存储桶)来整合数据。在处理数据帧之前,我们会遍历切片并将数据帧“合并”成一个大的数据帧,其中包含许多法律/会计规则。

它在 goroutine 中运行,以尽快索引所有数据点。

所以实现本质上是一个 sync.Map[string, []DataFrame] 但我注意到虽然映射操作受到保护,但附加到数据帧切片却不受保护。每个哈希值每晚在该切片中可能有大约 20-30 个文件引用。

在过去的两年里,客户数据很有可能被错误地合并,我的任务是修复它。在sync.map之前,他们再次使用了带有Map的RWMutex,但不是切片,它指向本文作为指南。

首先,包含切片的 Map 的想法是适当的数据结构吗?

我尝试创建一个基于 RWMutex 的切片处理程序,但想知道 Map 是否可以有一个 chan DataFrame 来代替在索引客户文件时放入,然后一旦完成,第二步将其合并到一个数组中(如len(chanx)) 会被知道吗?

我主要来自 Java,所以我可能对一些术语感到困惑,所以我很抱歉。

解决方法

您有两个不同的问题:

  1. 更新地图时出现并发问题
  2. 更新地图条目时出现并发问题

sync.Map 将防止 1,但不能防止 2。

解决这个问题的一种方法是:

sync.Map[string, *DFrame]

哪里

type DFrame struct {
  sync.RWMutex 
  Data []DataFrame
}

一旦从地图中获取条目,您应该 LockRLock 它,然后使用数据。这不仅仅限于切片的附加。即使您只从数据帧中读取,您也必须 RLock 该结构。

因此,如果您要附加新的数据框:

df := &DFrame{}
entry,_:=m.LoadOrStore(key, df)
dfEntry:=entry.(*DFrame)
dfEntry.Lock()
dfEntry.Data=append(dfEntry.Data, newDataFrame)
dfEntry.Unlock()

以上就是golang 中带有切片的并发映射的详细内容,更多请关注编程网其它相关文章!

您可能感兴趣的文档:

--结束END--

本文标题: golang 中带有切片的并发映射

本文链接: https://lsjlt.com/news/563418.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • golang 中带有切片的并发映射
    php小编香蕉带来了一篇精彩的文章,讲述了golang中切片的并发映射。在这篇文章中,我们将了解如何在并发环境中使用切片进行映射操作,并解释了为什么切片在并发编程中非常有用。通过使用g...
    99+
    2024-02-11
    golang开发
  • 在 Golang 的结构体中分配切片映射
    各位小伙伴们,大家好呀!看看今天我又给各位带来了什么文章?本文标题是《在 Golang 的结构体中分配切片映射》,很明显是关于Golang的文章哈哈哈,其中内容主要会涉及到等等,如果能帮到你,觉得很...
    99+
    2024-04-04
  • Golang函数参数传递中切片和映射的处理
    在 go 中函数参数传递时,切片和映射会传递引用,而不是值。切片在函数中修改会影响调用函数中的切片。映射在函数中修改也会影响调用函数中的映射。若需要传递副本,可以使用 copy 函数。多...
    99+
    2024-04-13
    映射 切片 golang
  • 使用golang中的sync.Map函数实现并发安全的映射
    标题:使用golang中的sync.Map函数实现并发安全的映射引言:在并发编程中,多个goroutine同时对同一个数据结构进行读写操作,会造成数据竞争和不一致的问题。为了解决这个问题,Go语言提供了sync包中的Map类型,它是并发安全...
    99+
    2023-11-18
    Golang 并发安全 syncMap
  • Go语言中的数组、切片和映射解析
    目录 数组数组的声明数组循环 切片切片声明切片元素循环 映射Map的声明及初始化Map的遍历 数组 数组存放的是固定长度、相同类型的数据,而且这些存放的元素是连续的。 数组的声...
    99+
    2023-09-08
    学习 go 青少年编程 开发语言
  • 详解Go语言中数组,切片和映射的使用
    目录1.Arrays (数组)2.切片2.1 make创建切片3.映射MapArrays (数组), Slices (切片) 和 Maps (映射) 是常见的一类数据结构 1.Arr...
    99+
    2024-04-02
  • Go语言中数组,切片和映射怎么使用
    这篇文章主要讲解了“Go语言中数组,切片和映射怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Go语言中数组,切片和映射怎么使用”吧!Arrays (数组), Slices (切片) ...
    99+
    2023-07-02
  • GoLang切片并发安全解决方案详解
    目录1.介绍切片并发问题2.实践检验真理3.回答切片并发安全问题4.解决切片并发安全问题方式5.附1.介绍切片并发问题 关于切片的,Go语言中的切片原生支持并发吗? 2.实践检验真理...
    99+
    2024-04-02
  • 映射中的多种函数类型,Golang
    映射是Golang中一种强大的数据结构,它允许我们将一个值与另一个值相关联。在Golang中,我们可以使用映射来实现各种不同类型的函数。php小编柚子将在本文中介绍映射中的多种函数类型...
    99+
    2024-02-12
    golang开发
  • 一文带你了解Golang中的并发性
    目录什么是并发性,为什么它很重要并发性与平行性Goroutines, the worker MortysChannels, the green portal总结并发是一个很酷的话题,...
    99+
    2023-03-15
    Golang并发性 Go 并发性
  • golang 切片中的内存泄漏
    Golang小白一枚,正在不断学习积累知识,现将学习到的知识记录一下,也是将我的所得分享给大家!而今天这篇文章《golang 切片中的内存泄漏》带大家来了解一下##content_title##,希...
    99+
    2024-04-04
  • 在 Golang 中编组有序映射时排序 JSON 键的问题
    在Golang中编组有序映射时,排序JSON键是一个常见的问题。当我们从数据库或其他数据源中获取数据并将其编组为JSON格式时,经常需要对键进行排序,以保证输出的JSON对象具有一致的...
    99+
    2024-02-09
    键值对
  • Golang:环境映射代码中的奇特语法
    对于一个Golang开发者来说,牢固扎实的基础是十分重要的,编程网就来带大家一点点的掌握基础知识点。今天本篇文章带大家了解《Golang:环境映射代码中的奇特语法》,主要介绍了,希望对大家的知识积累...
    99+
    2024-04-04
  • golang 中的 sqlx - 是否可以映射连接表?
    偷偷努力,悄无声息地变强,然后惊艳所有人!哈哈,小伙伴们又来学习啦~今天我将给大家介绍《golang 中的 sqlx - 是否可以映射连接表?》,这篇文章主要会讲到等等知识点,不知道大家对其都有多少...
    99+
    2024-04-04
  • ECMAScript6中Map映射的有什么用
    这篇文章主要介绍了ECMAScript6中Map映射的有什么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。映射(Map)是 ECMAScript 6 规范中引入的一种数据结...
    99+
    2023-06-20
  • 怎么用vbs找到映射到共享的所有驱动器并重新映射它们
    这篇文章主要介绍“怎么用vbs找到映射到共享的所有驱动器并重新映射它们”,在日常操作中,相信很多人在怎么用vbs找到映射到共享的所有驱动器并重新映射它们问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么用vb...
    99+
    2023-06-08
  • 一文浅析Golang中的切片(Slice)
    本篇文章带大家学习一下Golang,聊聊Go语言基础中的切片(Slice),希望对大家有所帮助。1.切片的定义从上一节我们知道,因为数组的长度是固定的并且数组长度属于类型的一部分,数组a中已经有三个元素了,我们不能再继续往数组a中添加新元素...
    99+
    2023-05-14
    切片 Golang go语言 Go
  • golang中的并发和并行
    golang中默认使用一个CPU,这时程序无法并发,只能是并发。因为始终只有一个CPU在运行。 package main import ( "fmt" ...
    99+
    2024-04-02
  • 切片在Golang中有何作用?全面分析
    切片在Golang中有何作用?全面分析 在Golang中,切片(slice)是一种非常重要且常用的数据结构,它可以看作是对数组的一个封装,实现了动态数组的功能。通过切片,我们可以更加灵...
    99+
    2024-03-03
    golang 切片 作用 内存占用
  • 迭代“interface{}”的映射并在 Golang 中的每个项目上调用相同的方法
    问题内容 我正在开发一个简单的控制台游戏来学习 go,并陷入了一个看似简单的问题,这在其他语言中没有问题,但在 go 中似乎几乎不可能。 我有一个接口映射作为结构中的字段,如下所示: ...
    99+
    2024-02-05
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作