聊聊并发编程,另送5本Golang并发编程新书

news2024/11/15 11:08:16

大家好,我是飞哥!

并发编程并不是一个新话题,但是我觉得在近几年以及未来的时间里,并发编程将显得越来越重要。

为什么这样讲,让我们先回到一个基本的问题上来,为什么我们要采用并发编程?关于这个问题可能会有多种答案,但是最根本的答案是受 CPU 硬件发展的影响。

摩尔定律原意说的是每隔 18 个月处理器的速度会翻一翻。从 1970 年到 2002 年的这段时间里,硬件确实大致是按照这个规律发展的。

但是进入到 2002 年之后,CPU 硬件的发展已经触达到了物理的极限,主频发展到 3.0 GHz 之后就开始已经原地踏步了,直到今天绝大部分 CPU 硬件的主频仍然是在这个频率附近徘徊。

但是软件的发展对算力的要求仍然在逐年提高,CPU 硬件厂商也要继续进步,怎么办?

接下来 CPU 硬件的发展就开始朝着另一个方向来发展,那就是在一台服务器内塞进更多的 CPU 核。手段有如下几个

  • 在单 CPU 架构内设计实现更多的物理核

  • 通过超线程技术将一个物理核当成两个核来用

  • 在一台服务器内通过 QPI/UPI 总线互联实现安装多个 CPU

拿单 CPU 架构设计来举例,我在深入了解服务器 CPU 的型号、代际、片内与片间互联架构中提到过,在 Intel 2015 年的 Broadwell 代际的服务器 CPU 中,采用的 Ring 架构就实现了单颗 CPU 塞进去 24 个物理核。

后来到了 2017 年后的 Skylake 、Cascade Lake,以及 2021 年的 ice lake 架构,都采用更高效的 mesh 多核互联新架构,将单 CPU 中物理核的数量提升到了 40 核。

AMD 的多核发展同样是如火如荼,在 AMD Zen 架构的 EPYC 9000 系列更是设计出了 92 的超高物理核核数。

以上各种手段带来的最终的结果就是一台服务器上 CPU 的主频虽然没有进步,但是编程可用的核越来越多。这对应用的编程也带来了新的挑战

  • 如何对应用逻辑进行并行化拆分

  • 如何更轻量地实现并行

  • 如何解决并行过程中出现的锁竞争的问题

  • 如何设计线程安全且高效的数据结构

  • 如何实现原子操作避免并发影响

基于以上问题,Go 语言之父 Rob Pike 一直认为 C++ 缺乏对新的多核机器的支持,他想尝试把多年来自己对并发编程的理解实现出来。所以 Go 语言的初衷就是让大家很方便地进行并发编程。

最近我的好友晁岳攀新出了一本《深入理解 Go 并发编程》,非常详尽地对 Go 语言中的并发技术点进行了阐述。

我和他要了 5 本,作为福利送给咱们的读者。中奖方式规则如下:

  • 评论区点赞前3名自动获得,

  • 另外两本由我在评论区选取两条优质评论

  • 为了防止灌水,评论字数需要大于10个字

  • 评论点赞时间截止时间到明天(2月3日)中午12:00

晁岳攀大佬网名鸟窝,是知名微服务框架rpcx的作者,2019 年也在极客时间上开办了专栏《Go 并发编程实战课》作者。前微博技术专家,目前就职于百度。

提到 Go 并发编程,一个常见的认识是 gorutine、select、channel 三件套。但其实从更全面的视角来看的话,Go 语言运行时中并发编程中相关的技术点很多,例如:

  • 互斥锁Mutex:用于控制多线程对共享资源的竞争访问同步机制。

  • 读写锁RWMutex:读写锁是一种对互斥锁Mutex的优化,可以允许多个gorutine同时读数据

  • WaitGroup:用于解决并发等待问题,用于在某个任务完成后再开始处理其它任务的任务编排

  • 条件等待Cond:当条件满足时唤醒一个或多个gorutine

  • 单例模式Once:用来执行仅仅执行一次的操作

  • 线程安全的Map:线程安全的sync.Map的使用方式以及实现原理

  • 对象池sync.Pool:通过池有效地减少对新对象的申请,提高程序性能

  • 原子操作atomic: 原子操作的使用场景和实现原理

  • 通道Channel:channle与gorutine一起提供了更优雅的并发编程方式

这本书对这些知识点全方位进行了阐述,这本书的目录如下:

4992bea8c4940d859e03efdddf6348bb.png

这本《深入理解 Go 并发编程》我觉得区别于其它的 Go 语言的书籍的特点是不光光讲这些技术怎么使用,还都从实现的角度分析了它们在底层是如何实现的。这是我个人比较喜欢的风格。只有这样才能真正对一个技术点理解通透。

比如对于互斥锁 Mutex,晁老师是从各个历史版本开始一直介绍到最新的 Mutex 的实现。

a257d5c95c2d71a4bf0f4f4222cbb7e0.png

这本书加入了大量精美的插图,使用卡通 Gopher 造型,结合中国传统造型,读者阅读起来会觉得趣味横生。

069ede00e63f45cda6c8a0c7615aaad3.png

没有中奖的同学也不要灰心,原价158,给大家要到的价格是74元,比5折还稍微便宜一点点。点击下面的链接选择下单即可。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1430801.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Gson源码解读

一,概述 gson作为流行的json工具,笔者使用较多。本文主要目的是解读下Gson的源码实现,就没有然后了。 二,实例 实例如下图所示,笔者简单调用gson的toJson方法获得json字符串,fromJson则从json字符串解析…

基于单片机的造纸纸浆液位控制系统结构设计

摘要:为适应无人化与高效化制浆造纸生产体系,造纸企业趋于以嵌入式技术优化造纸过 程中的纸浆液位控制系统,以单片机与传感器相互耦合实现纸浆液位控制。本文基于单片机 设计了造纸纸浆液位控制系统,其结构由控制模块、信息采集模块、物联网模…

ASP.NET Core 自定义解压缩提供程序

写在前面 在了解ASP.NET Core 自定义请求解压缩中间件的应用时,依据官方文档操作下来碰到了几个问题,这边做个记录。 关键点就是配置 Content-Encoding,参数需要和代码中添加的提供程序的Key保持一致; builder.Services.AddRequ…

(bean配置类的注解开发)学习Spring的第十三天

bean配置类的注解开发 问题提出 用类充当配置文件 applicationcontext.xml : Configuration注解标识此类为配置类,替代原有xml文件 看原配置文件applicationcontext.xml代码 <?xml version"1.0" encoding"UTF-8"?> <beans xmlns"http:/…

ctfshow——文件包含

文章目录 web 78——php伪协议第一种方法——php://input第二种方法——data://text/plain第三种方法——远程包含&#xff08;http://协议&#xff09; web 78——str_replace过滤字符php第一种方法——远程包含&#xff08;http://协议&#xff09;第二种方法——data://&…

FPGA项目(16)——基于FPGA的音乐演奏电路

1.设计要求 能在实验箱上&#xff0c;循环播放一段音乐。&#xff08;需要源码的直接看最后一节&#xff09; 2.设计原理 组成乐曲的每个音符的发音频率值及其持续的时间是乐曲能连续演奏所需要的两个基本要素&#xff0c;问题是如何来获取这两个要素所对应的数值以及通过纯硬件…

2024.2.3

单向循环链表的头插 头删 尾插和尾删 //头结点插入 Linklist insere_element(Linklist head,datatype element) {Linklist screat();s->dataelement;if(NULLhead){heads;}else{Linklist phead;while(p->next!head){pp->next;}s->nexthead;heads;p->nexthead;}r…

探索前端开发框架:React、Angular 和 Vue 的对决(一)

&#x1f90d; 前端开发工程师、技术日更博主、已过CET6 &#x1f368; 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 &#x1f560; 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》 &#x1f35a; 蓝桥云课签约作者、上架课程《Vue.js 和 E…

Linux下vim命令详解

vim #创建或编辑新的文件 #这将在当前目录下创建一个名为fi.txt的新文本文件。如果文件已经存在&#xff0c;将会编辑现有文件。 [rootsever ~]#vim fi.txt #对于普通的文本编辑操作&#xff0c;可以使用以下键盘命令&#xff1a; - i&#xff1a;进入插入模式&#xff…

[职场] 英语面试自我介绍 #微信#笔记#媒体

英语面试自我介绍 英语面试自我介绍1 I am very happy to introduce myself here.I was born in Liaoning Province.I graduated from Nankai University and majored in International Trade.I like music and reaing books,especially economical books.It is my honor to ap…

回归预测 | Matlab基于OOA-LSSVM鱼鹰算法优化最小二乘支持向量机的数据多输入单输出回归预测

回归预测 | Matlab基于OOA-LSSVM鱼鹰算法优化最小二乘支持向量机的数据多输入单输出回归预测 目录 回归预测 | Matlab基于OOA-LSSVM鱼鹰算法优化最小二乘支持向量机的数据多输入单输出回归预测预测效果基本介绍程序设计参考资料 预测效果 基本介绍 Matlab基于OOA-LSSVM鱼鹰算法…

Java数组声明、创建、赋值和使用

目录 数组的定义数组的创建访问数组元素遍历数组数组实例分析 数组的定义 数组是相同类型数据的有序集合。数组描述的是相同类型的若干个数据&#xff0c;按照一定的先后次序排列组合而成。其中&#xff0c;每一个数据称作一个元素&#xff0c;每个元素可以通过一个索引&#…

[word] word表格两列互换 #学习方法#其他

word表格两列互换 Word表格也常用的数据表&#xff0c;在使用表格时&#xff0c;不管是编辑数据&#xff0c;调整数据&#xff0c;还是删除数据&#xff0c;都是有小技巧的&#xff0c;今天给大家分享word表格两列互换的小技巧&#xff0c;简单又实用。 1、两列互换 那么两列…

太强了,AI数字人从制作到变现一次搞定

AI数字人从制作到变现 如果说GPT类大模型是我们人类的第二大脑&#xff0c;数字人就是我们人类在互联网上的第二个身体。随着 AI 的迅速发展&#xff0c;2024 年 AI 模型开始从大型语言模型向大型视觉模型转变。数字人技术作为其分支之一&#xff0c;正日益成为科技、娱乐、教…

算法42:天际线问题(力扣218题)---线段树

218. 天际线问题 城市的 天际线 是从远处观看该城市中所有建筑物形成的轮廓的外部轮廓。给你所有建筑物的位置和高度&#xff0c;请返回 由这些建筑物形成的 天际线 。 每个建筑物的几何信息由数组 buildings 表示&#xff0c;其中三元组 buildings[i] [lefti, righti, heig…

中国大学生计算机设计大赛与大数据应用主题赛

中国大学生计算机设计大赛 与大数据应用主题赛 中国大学生计算机设计大赛&#xff08;简称“大赛”或4C&#xff09;始筹于2007年&#xff0c;首届于2008年&#xff0c;已经举办了16届80场赛事。是我国高校面向本科生最早的赛事之一&#xff0c;由教育部计算机类教指委发起举…

Android Button background 失效

问题 Android Button background 失效 详细问题 笔者开发Android项目&#xff0c;期望按照 android:background中所要求的颜色展示。 实际显示按照Android 默认颜色展示 解决方案 将xml的Button 组件修改为<android.widget.Button> 即将代码 <Buttonandroid:l…

有趣的CSS - css loading动画

Loading动画 整体效果核心代码html 代码&#xff1a;css 部分代码&#xff1a; 完整代码如下html 页面&#xff1a;css 样式&#xff1a;页面渲染效果&#xff1a; 整体效果 这个 Loading 效果主要用 css3 的 animation 属性配合 border 属性来实现的。 可以用作在下拉列表 Loa…

如何写好论文——(14)写作时如何定义和描述研究目标

当我们有了一个具体的细化的研究目标之后&#xff0c;我们需要把它清晰准备描述给我们的读者&#xff0c;并用它来指导我们的研究活动。 一、有方向 我们所选择的具体的研究目标一定要有明确的目标指向&#xff0c;那就是我们的长远目标。 二、有边界 我们要明确自己的研究…

在WORD中设置公式居中编号右对齐设置方式

1 软件环境 Office Microsoft Office LTSC 专业增强版2021 2 最终效果 3 操作步骤 编辑公式&#xff1b;光标定位到公式的最后&#xff08;不是行的最后&#xff09;&#xff1b;输入#编号光标定位在公式最后&#xff08;不是行的最后&#xff09;&#xff0c;按Enter键回车…