并发中的原子性问题

高级语言的程序中,一条程序代码,可能对应多个CPU指令,而原子性,即指一个或多个操作在cpu中执行的过程中不被中断,称为“原子性”。
而因为原子性出现的bug的原因是因为线程切换,即指一个变量的读取操作在cpu中可能存在多个线程同一时间执行不同的顺序,导致值的不对。
怎么解决这个问题呢?原子性问题的根源,就是因为CPU中断,那么禁止线程切换,不就能够解决这个问题,而禁止cpu发生中断就能禁止线程切换。
而在多核CPU上,同一时间运行同一段代码,禁止线程切换,代表cpu执行代码不会中断,但是,同时不能保证同一时刻只有一个线程执行。如果两个线程同时对一个共享变量操作,那么还是会存在并发性问题。

那怎么保证不存在多个线程执行同一段代码,答案就是互斥。保障同一段代码只有一个cpu执行。解决办法就是:加锁。

即synchronize关键字,主要理解好,我们的锁和我们所保护的资源的关系弄清楚。即锁来自哪里,它保护谁,一般情况下都会弄错,即A锁保护B的资源。多个资源怎么保护,这个时候弄清楚资源之间的关系,是共用一把锁保护,还是分开用多个锁保护。
这是保证互斥的关键。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值