Go并发编程和调度器
创始人
2025-01-11 11:37:48
0

为什么我们要采用并发编程呢?这个问题很重要,也是我们在动手写代码之前必须要考虑的一个问题,它决定了程序的设计方式。

事实上,在某些场景下,比如编写一个 “hello world" 程序,解决一道力扣上的难题,编写一个简单的运维工具,我们都不需要考虑并发编程的问题,简单地编写一个顺序执行(也叫串行执行)的程序就可以了。但是在大部分场景下,尤其是要执行一些复杂的业务逻辑时,我们想并发地执行一些业务逻辑,比如同时执行对 N 个网站的请求,或者并发地处理客户端的请求,然后交给一个 worker 池去处理,在这些场景下,我们就需要考虑并发的问题了。

并发编程,目的就是提高程序的吞吐能力和性能,能够同时处理很多业务,而不管这些业务是相同的还是不同的。为什么并发编程能提升程序的吞吐能务和性能呢?原因如下:

合理地拆解程序的逻辑,使不同的业务模块可以并发执行,同时可以处理多个业务模块,从而在相同的时间内有更多的业务单元可以被处理。在串行编程的模式下,必须一个模块执行完,才能执行下一个模块,其中一个模块在执行的时候,其他模块就一直在等待,同一个时间点只能有一个模块执行。

当然,对程序的拆解并不是一件容易的事情。因为业务逻辑中有些部分必须等待其他并发部分全部或者部分完成后才能执行,比如统计访问几大搜索网站的平均延迟,统计模块需要等待访问百度、bing、谷歌等并发模块都返回结果后才能进行统计。我们把这种需要多个并发模块协调的逻辑处理叫作编排。

对于I/O敏感型的程序,并发编程对其性能的提升巨大。I/O 敏感型的程序会将大量的时间耗费在等待 I/O 完成上,比如从网络中读取数据,往磁盘中写入批量的持久化数据,或者访问一个数据库等。对于串行编程模型,程序在等待的过程中不能执行其他业务逻辑(即使CPU空闲);但是对于并行编程模型,程序在等待 I/O 完成的过程中完全可以处理其他业务逻辑,程序不会被阻塞,所以并行对 I/O 敏感型程序的性能提升有时候是巨大的。

并发编程可以充分利用现代 CPU 的多核能力。从 1970 年到 2002年,处理器的速度大约每 18 个月翻一番,所以当时调侃程序员对程序的优化就是耐心等待,等待新的 CPU出现,程序在新的 CPU 上运

相关内容

热门资讯

详细透视!aapoker透视脚... 详细透视!aapoker透视脚本下载,hh poker软件,手筋教程(详细教程)-哔哩哔哩1、进入游...
普及透视!聚星ai辅助工具收费... 普及透视!聚星ai辅助工具收费多少,微乐自建房免费辅助入口在哪里,妙计教程(有挂透视)-哔哩哔哩1、...
连日来!途游游戏辅助脚本(辅助... 连日来!途游游戏辅助脚本(辅助)真是真的是有辅助下载(有挂方法)-哔哩哔哩暗藏猫腻,小编详细说明途游...
今日重大通报!欢乐达人葫芦鱼辅... 今日重大通报!欢乐达人葫芦鱼辅助,hhpoker德州机器人,教程书教程(有挂技巧)-哔哩哔哩1、实时...
详情透视!wepoker透视脚... 详情透视!wepoker透视脚本是什么,hhpoker一直输有挂吗,攻略教程(果真有挂)-哔哩哔哩暗...
连日来!楚天游卡五星辅助器(辅... 连日来!楚天游卡五星辅助器(辅助)好像存在有辅助器(有挂讲解)-哔哩哔哩1、楚天游卡五星辅助器辅助器...
关于透视!wpk辅助软件,微信... 关于透视!wpk辅助软件,微信小程序微乐辅助器真吗,法门教程(今日头条)-哔哩哔哩1、完成wpk辅助...
重大通报!江汉晃晃辅助器,we... 重大通报!江汉晃晃辅助器,wepoker作必弊视频,操作教程(有挂分析)-哔哩哔哩1、起透看视 江汉...
揭幕透视!aapoker能控制... 揭幕透视!aapoker能控制牌吗,epoker底牌透视,窍要教程(有挂详细)-哔哩哔哩1、在aap...
针对!四川游戏家园辅助器(辅助... 针对!四川游戏家园辅助器(辅助)原来真的是有辅助软件(有挂分享)-哔哩哔哩1、进入游戏-大厅左侧-新...