二、RPC和Threads

1、本课程使用go语言作为编程语言
(1)优点
在这里插入图片描述
在这里插入图片描述
2、Threads
(1)分布式系统的RPC首先应该考虑现线程在这里插入图片描述
(2)分布式系统考虑线程的原因
在这里插入图片描述

a、IO并发
overlapping of the progress of different activities , allowing one activity awaiting and other activities can proceed
在这里插入图片描述

在这里插入图片描述
例如下图RPC时候,一个线程调用rpc了会一直等待着
在这里插入图片描述

b、multiple core parallelism
并行
在这里插入图片描述
实体物理cpu定义的线程,真正意义上的同时进行,就像你电脑的cpu的多核多线程,用多线程提高效率
在这里插入图片描述
在这里插入图片描述
c、便利性
例如我想周期性地执行一些代码

事件驱动
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述
多线程的好处
在这里插入图片描述
在这里插入图片描述
(3)多线程编程挑战
在这里插入图片描述

(3.1)全局变量n递增问题
在这里插入图片描述
第一个线程load x进入寄存器
然后add 1,进入寄存器
然后store进入寄存器
在这里插入图片描述

(3.2)互斥锁

在这里插入图片描述
(3.3)锁协调问题
在这里插入图片描述
a、通道方式解决
在这里插入图片描述
b、同步条件变量
在这里插入图片描述
c、等待组
在这里插入图片描述
(4)死锁
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值