在IEEE1364—1995 Verilog标准的5.3节定义了层次化的事件队列在逻辑上分为用于当前仿真时间的4个不同的队列,用于下一段仿真时间的若干附加队列。
(1)动态事件队列(下列事件执行的顺序随机安排)
① 阻塞赋值;
② 计算阻塞赋值右边的表达式;
③ 连续赋值(对wire型变量用assign赋值);
④ 执行$display命令;
⑤ 计算原语的输入与输出变化。
(2)停止运行的时间队列: #0 延时阻塞赋值。
(3)非阻塞事件队列:更新非阻塞赋值语句LHS(<=左边的变量)的值。
(4)监控事件队列:
① 执行$monitor命令;
② 执行$strobe命令。
(5)其他指定的PLI命令队列:其他PLI命令。
下面用一张图来表示:
动态事件就是活跃事件,它们的优先级最高,在当前的仿真时间中,活跃事件最先被执行。
上图可以看出,阻塞赋值是活跃事件,当前仿真时间中它最先被执行,阻塞赋值执行完RHS(右式计算&