如何解决并发

并发产生的原因

虽然从宏观上,处理器是并行处理多项任务,但本质上一个处理器在某个时间点只能处理一个任务,属于串行执行。在单处理器的情况下,并发问题源于多道程序设计系统的一个基本特性:进程的相对执行速度不可预测,它取决于其他进程的活动、操作系统处理中断的方式以及操作系统的调度策略。在分布式环境下,并发产生的可能性就更大了,只要大家有依赖的共享资源,就有并发问题的出现,因为互相调用次序更加没法控制。

并发导致的问题

全局资源的共享充满了危险。不同任务对同一个共享资源的读写顺序非常关键
操作系统很难对分配资源进行最优化管理。挂起的线程占有了其他活动线程需要的资源

定位错误非常困难。这种问题来源和触发的不确定性,导致定位问题非常困难
限制分布式系统横向扩展能力

具体解决方法

一次只允许一个进程进入临界区
一个非临界区停止的进程必须不干涉其他进程
不允许出现一个需要访问临界区的进程被无限延迟
一个进程驻留在临界区中的时间必须是有限的
临界区空闲时,任何需要进入临界区的进程必须能够立即进入

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值