阻塞赋值:当前语句没有执行完以前不会执行下一条语句,只有当当前语句中的“计算”完成之后,直接赋值,下一条语句才会执行;
reg x,y,z;
reg [15:0] reg_a,reg_b;
integer count;
initial
begin
x = 0; y = 1; z = 1;
count = 0;
reg_a = 16'b0; reg_b = reg_a;
#15 reg_a[2] = 1'b1;
#10 reg_b[15:13] = {x,y,z};
count = count + 1;
end
各条语句执行的顺序为:
(1)x = 0 到reg_b = reg_a之间的语句在0时刻执行;//可以认为执行这些语句所需的时间为0,但是在实际电路中有延迟,所以使用阻塞赋值时要考虑实际情况
(2)reg_a[2] = 0在时刻15执行;
(3)reg_b[15:13] = {x,y,z} 在时刻25执行;
(4)count = count + 1在时刻25执行。
非阻塞赋值:当前语句不会阻碍下一条语句的执行,但是只有块结束时才会赋值。
reg x,y,z;
reg [15:0] reg_a,reg_b;
integer count;
initial
begin
x = 0; y = 1; z = 1;
count = 0;
reg_a = 16'b0; r