复杂指令集与精简指令集的原子操作

复杂指令集与精简指令集的原子操作

以a++的动作为例:

 

在精简指令集下,这个加法操作不是原子的,包括多个汇编步骤,典型的情况包括3个步骤:ldr、add、str,即读取内存数据到CPU寄存器,修改数据,将修改后的数据存入内存(读、修改、写,也叫做RMW原则),如下所示:

在复杂指令集下,可以直接在内存上进行加减动作,一条add汇编指令即可完成,因此在单核情况下,这个a++的动作是原子的。但是,在多核情况下,a++的操作并不是原子的,因为你做a++之前,有可能被其它核上的高优先级线程抢占并先一步做完a++,然后等到你做a++的时候,结果就相当于做了两遍a++,这显然与你的预期结果不符合,因为你期望获得的是做一遍a++的结果。正因如此,我们在编写底层代码的时候,都应该假设当前的环境是多核的,并按照多核环境来编程。

 

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值