如何知道谁能给好好解释下非阻塞赋值和阻塞赋值呢?

[复制链接]
5956|28
 楼主| 星星之火红 发表于 2011-7-9 18:51 | 显示全部楼层 |阅读模式
有点糊涂啊:(
GoldSunMonkey 发表于 2011-7-9 19:00 | 显示全部楼层
先说下:组合逻辑中是实时变化的,而时序逻辑中一个cycle才变化一次
比如:
always @(a or b)
begin
    c = a + b;
end
always @(posedge clk)
begin
    if(rst)
      c <= 0;
   else
     c <= a + b;
end
在组合逻辑的always block中,a和b的变化都会引起c值的变化;
而时序逻辑中c至少会维持一个clock cycle,也就是说如果a和b的变化导致c变化的时间是在下一个clock的上升沿,而不会让c立刻改变
---------------------------------------------------------
好,说正题
阻塞赋值“=”与非阻塞赋值“<=”的本质区别在于:
非阻塞赋值语句右端表达式计算完后并不立即赋值给左端,而是同时启动下一条语句继续执行,可以将其理解为所有的右端表达式RHS1、RHS2等在进程开始时同时计算,计算完后 ,等进程结束时同时分别赋给左端变量LHS1、LHS2等;
而阻塞赋值语句在每个右端表达式计算完后立即赋给左端变量,即赋值语句LHS1=RHS1执行完后LHS1是立即更新的,同时只有LHS1=RHS1执行完后才可执行语句LHS1=RHS2,依次类推。前一条语句的执行结果直接影响到后面语句的执行结果。

评分

参与人数 2威望 +3 收起 理由
SuperX-man + 2
星星之火红 + 1

查看全部评分

 楼主| 星星之火红 发表于 2011-7-9 19:01 | 显示全部楼层
Monkey侠,谢谢啦。明白了。
AutoESL 发表于 2011-7-9 22:38 | 显示全部楼层
2# GoldSunMonkey
学习了,很不错,解释的很好
ertu 发表于 2011-7-9 22:45 | 显示全部楼层
确实不错
ertu 发表于 2011-7-9 22:45 | 显示全部楼层
:handshake
GoldSunMonkey 发表于 2011-7-11 10:02 | 显示全部楼层
dan_xb 发表于 2011-7-11 10:07 | 显示全部楼层
GoldSunMonkey 发表于 2011-7-11 13:24 | 显示全部楼层
 楼主| 星星之火红 发表于 2011-7-11 14:26 | 显示全部楼层
孙大圣,谢谢啦~~ :victory:
GoldSunMonkey 发表于 2011-7-11 16:31 | 显示全部楼层
;P我是大圣~
wewo 发表于 2011-7-12 20:39 | 显示全部楼层
大胜好呀
wewo 发表于 2011-7-12 20:39 | 显示全部楼层
GoldSunMonkey 发表于 2011-7-13 09:51 | 显示全部楼层
jennyzheng 发表于 2011-7-13 10:57 | 显示全部楼层
讲的很好~
jioa 发表于 2011-7-13 16:42 | 显示全部楼层
还是超版厉害呀
jioa 发表于 2011-7-13 16:43 | 显示全部楼层
:victory:
GoldSunMonkey 发表于 2011-7-13 17:33 | 显示全部楼层
:'(没天理了,我回答问题,为什么变成了超版厉害,为什么是SuperX-man厉害呢?
cbas 发表于 2011-7-14 14:15 | 显示全部楼层
版主也好呀
cbas 发表于 2011-7-14 14:16 | 显示全部楼层
估计是看错了吧
您需要登录后才可以回帖 登录 | 注册

本版积分规则

101

主题

1782

帖子

22

粉丝
快速回复 在线客服 返回列表 返回顶部