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

理解Go语言中多种并发模式

        Go 的同步原语使实现高效的并发程序成为可能,并且选择合适的同步原语和并发模式可以更加容易地实现并发的可能,减少错误的发生。这里谈论的并发模式是只在 Go 语言中常见的并发的“套路” ,一种可解决某一类通用场景和问题的惯用方法。

1. 并发模式概述

        我们先来回顾下同步原语以及它们所解决的问题。

  • Mutex: 解决共享变量或者临界区的并发访问问题
  • RWmutex: 解决在多读少写的场景下互斥锁的并发性能问题。
  • WaitGroup: 解决等待一组子任务完成的问题。
  • Cond: 解决条件满足后通知的问题,单个通知或者全部通知。
  • Once: 解决单次初始化的问题。
  • sync.Map :实现线程安全(goroutine 并发访问安全)的 map 对象
  • Pool:池化对象,重用对象,如果对象的创建和销毁太消耗资源,那么使用池化技术可以很好地解决问题。
  • Context: 提供上下文传递、撤销以及超时的功能,控制子 goroutine 。
  • atomic :对象的原子操作
  • channel:包括多种模式--信息交流、数据传递、信号通知、任务编排和互斥锁,其中任务编排具体包括 Or-Done 模式、扇入模式、扇出模式、Stream 模式、管道模式、map-reduce 模式等。
  • 信号量:对 n 个资源的同步保护
  • SingleFlight: 对统一资源并发访问的控制,通常用于解决缓存击穿等问题。
  • CyclicBarrier: 在循环屏障的使用场景中,参与者需要相互等待。单个屏障可以使用 WaitGroup 或者 channel 实现。
  • 分组操作: 解决处理一组任务时的同步问题。
  • 限流:解决单个进程或者分布式调用的限流问题,一般采用漏桶或者令牌桶实现限流。
  • 分布式同步原语:主要基于 etcd 实现的同步原语,包括选举、锁、队列、屏障、STM等。

2. 并异步/并同步模式

        半异步/半同步( Half-Async/Half-Sync) 模式是一种用于处理异步和同步操作的并发模式,它结合了两种并发模型的优点,以便在异步操作和同步操作之间平衡。这种模式通常被用来开发网络应用程序,以及其他需要同时处理异步和同步操作的程序。

        这种模式的优点在于,程序员可以利用异步操作的高性能和高吞吐量能力,同时也可以利用同步操作的简单性和易用性。假设有一个网络应用程序,需要处理大量的传入和传出的数据,同时还需要响应用户的同步请求,例始,用户在客户端界面上点击某个按钮。在这种情况下,可以使用半异步/半同步模式来平衡异步操作和同步操作的处理。

        在这个例子中,程序可以创建一个异步线程池,用于处理所有的传入和传出的数据。当传入数据时,程序会将其放入异步队列中,然后异步线程池会从队列中取出数据并进行异步操作,如解析数据、执行计算或将其存储到数据库中。在这个过程中,主线程可以继续响应其他的同步请求。

        同时,程序还可以在主线程中创建一个同步事件处理程序,用于响应用户的同步请求。例如,当用户在客户端界面上点击某个按钮时,程序会将该事件放入同步队列中,然后同步事件处理程序会从队例中取出事件并执行相关操作,如更新界面、执行计算或发送请求。

        通过这种方式&

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 2024年6月 青少年机器人技术等级考试理论综合试卷(二级)
  • 文件共享服务NFS(服务名nfs,端口tcp/2049)
  • Codeforces 874 div3 A-G
  • pytorch setattr vs. add_module区别
  • 【日常记录-MySQL】MySQL设置root用户密码
  • 英语文化中的音乐分类及其发展历史(Classical、Jazz、Rock、Pop、Electronic、Country、RB、Hip-Hop)
  • 虚拟dom-Diff算法
  • 通过docker-compose 部署misskey 服务器
  • 开发输出防护栏以检测GPT-4o幻觉
  • 基于springboot3实现单点登录(二):认证服务端搭建
  • 【递归】什么是递归-C语言为例
  • Linux安全与高级应用(九)Linux远程访问与控制:安全与最佳实践
  • 通过python管理mysql
  • 【Qt中2D绘图的类有哪些】
  • 【面试之算法篇】寻找二叉树中两个节点的最低公共祖先
  • 【Linux系统编程】快速查找errno错误码信息
  • 【翻译】babel对TC39装饰器草案的实现
  • Javascript基础之Array数组API
  • Js基础知识(一) - 变量
  • Linux后台研发超实用命令总结
  • Linux下的乱码问题
  • Sequelize 中文文档 v4 - Getting started - 入门
  • Unix命令
  • 分布式事物理论与实践
  • 干货 | 以太坊Mist负责人教你建立无服务器应用
  • 聊聊flink的TableFactory
  • 深入浏览器事件循环的本质
  • 算法系列——算法入门之递归分而治之思想的实现
  • 通过git安装npm私有模块
  • 微信小程序开发问题汇总
  • 线上 python http server profile 实践
  • 延迟脚本的方式
  • 自制字幕遮挡器
  • 7行Python代码的人脸识别
  • 智能情侣枕Pillow Talk,倾听彼此的心跳
  • ​批处理文件中的errorlevel用法
  • ​软考-高级-信息系统项目管理师教程 第四版【第19章-配置与变更管理-思维导图】​
  • $.ajax()参数及用法
  • (¥1011)-(一千零一拾一元整)输出
  • (9)STL算法之逆转旋转
  • (day6) 319. 灯泡开关
  • (react踩过的坑)Antd Select(设置了labelInValue)在FormItem中initialValue的问题
  • (二十九)STL map容器(映射)与STL pair容器(值对)
  • (转)Mysql的优化设置
  • .apk 成为历史!
  • .locked1、locked勒索病毒解密方法|勒索病毒解决|勒索病毒恢复|数据库修复
  • .Net Core与存储过程(一)
  • .NET MVC第五章、模型绑定获取表单数据
  • .NET 某和OA办公系统全局绕过漏洞分析
  • .NET/C#⾯试题汇总系列:集合、异常、泛型、LINQ、委托、EF!(完整版)
  • .Net8 Blazor 尝鲜
  • ??javascript里的变量问题
  • @RequestBody与@ResponseBody的使用
  • @Responsebody与@RequestBody
  • [ 蓝桥杯Web真题 ]-布局切换