阻塞与非阻塞

2019-03-25 09:56发布

always @(a or b or c) begin     x=c+y;//语句1     y=a+b;//语句2 end    y原来的值是5; a=1; b=1; c=3; 我仿真的结果是 x=5+3=8    y=1+1=2 资料上的解释是说 语句1和语句2同时进行,但是由于是阻塞赋值,所以要等语句1执行完了之后才能执行第二条语句,所以语句1中的值是原来的值; 与我自己的仿真结果一致;   always @(a or b or c) begin x<=c+y; y<=a+b; end y原来的值是5; a=1; b=1; c=3; 仿真的结果是 x=8 y=2; 我看的资料上说 在此时刻 x=3+2=5   y=1+1=2 他的意思是说 a+b 的值给 y ;然后 y+c的值再给x; 仿真的结果和 资料上说的不一样 求指教!!!! 此帖出自小平头技术问答
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
3条回答
梦之旅
2019-03-25 18:06
< / 后面那个工具默认优化的吧,要不我认为会有竞争和冒险的风险,看下RTL电路图就知道了,这个纯个人看法,因为没有这样写过........

一周热门 更多>