verilog 并列 连续赋值

当事件发生时,对于代码块中的非阻塞赋值语句,先计算所有非阻塞语句在【事件发生时刻】的值,(即以<=右端表达式的值),最后才把计算出的值赋给<=左边的变量。
计算过程是以代码块中语句的书写顺序进行。虽有先后顺序,但<=右端表达式中变量的值均为【事件发生时刻】时的值。

1

2

3

4

5

6

always @(posedge clk) begin  // 时间点:clk上升沿事件发生时刻

  a <= 1;  // 事件发生时刻,a_temp = 1

  a <= 2;  // 事件发生时刻,a_temp = 2

  a <= 3;  // 事件发生时刻,a_temp = 3

end

// 在事件完成时刻,更新变量a的值 a = a_temp = 3



同一语句块中非阻塞重复赋值,虽然符合语法语义,但应杜绝出在在设计中。考察下面两语句块

1

2

3

4

5

6

7

8

9

10

11

12

13

// 这段代码可以实现计数和清0

// 第2句只在条件满足时才对a_temp赋值为0,其它时候取第1句的赋值

always @(posedge clk) begin

  a <= a + 1;             // 事件发生时刻,a_temp =【事件发生时刻的a】+ 1

  if( a == 10 ) a <= 0;   // 事件发生时刻,if(【事件发生时刻的a】== 10 ) a_temp = 0

end

 

// 这段代码只能实现计数,不能实现清零。

// 第2句任何时候都会再次对a_temp赋值为a+1,相当于第1句任何时候都不起作用

always@(posedge clk) begin

  if( a == 10 ) a <= 0;   // 事件发生时刻,if(【事件发生时刻的a】== 10 ) a_temp = 0

  a <= a + 1;             // 事件发生时刻,a_temp =【事件发生时刻的a】+ 1

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

简单同学

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值