for 循环:
module ForLoopExample;
reg [7:0] data [0:9];
reg [7:0] sum;
initial begin
sum = 8'b0;
// 使用 for 循环初始化数据
for (int i = 0; i < 10; i = i + 1) begin
data[i] = $random; // 生成随机数
sum = sum + data[i];
end
// 在仿真输出数据
$display("Sum: %b", sum);
$stop; // 停止仿真
end
endmodule
在上面的例子中,for 循环用于初始化数组 data 中的元素,并计算它们的总和。
while 循环:
module WhileLoopExample;
reg [7:0] count;
reg [7:0] threshold;
initial begin
count = 8'b0;
threshold = 8'b100;
// 使用 while 循环
while (count < threshold) begin
$display("Count: %b", count);
count = count + 1;
end
$stop; // 停止仿真
end
endmodule
在上面的例子中,while 循环用于循环打印 count 的值,直到 count 达到 threshold。
需要注意的是,在硬件描述语言中,循环通常在测试台中使用,而在硬件设计中,很少使用显式的循环结构,因为硬件描述语言主要描述的是硬件电路的行为,而不是过程性的控制流。
转载请注明出处:http://www.pingtaimeng.com/article/detail/11030/Verilog