先说明一下 a=a+1这条程序语句的执行步骤:
javascript:;
我在想这种情况:
如果执行到第一步,将a的值读到寄存器R中
执行完这一条后,来了个中断就是 a=a-1 !
等执行完 a=a-1 ,这时候重点来了!
我的CPU会回到 a=a+1 的第二步!
R寄存器里面是不知道 a 已经被改变了,所以他还是按照原先的值 加1!
然后在写回到 a !
这时候就会出现bug了!
这种情况大伙们有考虑过吗? 要怎么避免?
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
- //中断里:
- write();
- count++;
- //后台里:
- if(count)
- {
- read();
- count--;//如果这里中断来了就出问题了,count的值不会不变,而会-1,总数不对
- //中断越频繁,越大几率出现这个BUG
- }
复制代码后来是加了锁,特殊处理一下才没问题。
嗯嗯,汇编还是相当重要的。看到下面redroof的回复,也意识到8位机也有这种问题的存在。单单靠现场保护也不够。
另外,许多人对LZ提出的问题不太理解, 看看 a++ 产生的指令就知道:
[a++]:
lw $8, [a]
add $8, $8, 1
sw $8, [a]
至少三条指令,这三条指令的序列被打断后对地址[a]进行修改都会造成错误结果;对8位机需要多个读-修改-写操作,但是本质还是一样的;
建议用生产消费模型,也就是中断内维护一个wr,任务里维护一个rd,if(wr != rd)表明有新的事件
一周热门 更多>