打印

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

[复制链接]
3787|28
手机看帖
扫描二维码
随时随地手机跟帖
沙发
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
学习了,很不错,解释的很好

使用特权

评论回复
5
ertu| | 2011-7-9 22:45 | 只看该作者
确实不错

使用特权

评论回复
6
ertu| | 2011-7-9 22:45 | 只看该作者
:handshake

使用特权

评论回复
7
GoldSunMonkey| | 2011-7-11 10:02 | 只看该作者
;P

使用特权

评论回复
8
dan_xb| | 2011-7-11 10:07 | 只看该作者

使用特权

评论回复
9
GoldSunMonkey| | 2011-7-11 13:24 | 只看该作者
;P

使用特权

评论回复
10
星星之火红|  楼主 | 2011-7-11 14:26 | 只看该作者
孙大圣,谢谢啦~~ :victory:

使用特权

评论回复
11
GoldSunMonkey| | 2011-7-11 16:31 | 只看该作者
;P我是大圣~

使用特权

评论回复
12
wewo| | 2011-7-12 20:39 | 只看该作者
大胜好呀

使用特权

评论回复
13
wewo| | 2011-7-12 20:39 | 只看该作者
:lol

使用特权

评论回复
14
GoldSunMonkey| | 2011-7-13 09:51 | 只看该作者
:lol

使用特权

评论回复
15
jennyzheng| | 2011-7-13 10:57 | 只看该作者
讲的很好~

使用特权

评论回复
16
jioa| | 2011-7-13 16:42 | 只看该作者
还是超版厉害呀

使用特权

评论回复
17
jioa| | 2011-7-13 16:43 | 只看该作者
:victory:

使用特权

评论回复
18
GoldSunMonkey| | 2011-7-13 17:33 | 只看该作者
:'(没天理了,我回答问题,为什么变成了超版厉害,为什么是SuperX-man厉害呢?

使用特权

评论回复
19
cbas| | 2011-7-14 14:15 | 只看该作者
版主也好呀

使用特权

评论回复
20
cbas| | 2011-7-14 14:16 | 只看该作者
估计是看错了吧

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

101

主题

1782

帖子

22

粉丝