在 SystemVerilog 中,ref
用于传递变量的引用(类似于 C 中的指针),而不是复制变量的值。
module ref_example;
function void modify_ref(ref int a);
a = a + 1;
endfunction
initial begin
int num = 5;
$display("Before modification: num = %0d", num);
modify_ref(num);
$display("After modification: num = %0d", num);
end
endmodule
//在上述示例中,modify_ref 函数接受一个 ref int 类型的参数 a,在函数内部对 a 进行修改,由于使用了 ref,这种修改会直接反映到原始的 num 变量上。
ref
只能用于带自动存储的子程序(如automatic function
、automatic task
、void function
)中。如果对程序或模块指定了automatic
属性,则整个程序内部都是自动存储的。