7.1 线程的使用
Verilog:begin…end中的语句以顺序方式执行,fork…join中的语句则以并发方式执行。
System Verilog:引入两种新的创建线程的方法——使用fork…join_none和fork…join_any语句。
fork…join_none块在调用其块内语句时,父线程继续执行。
fork…join_any块在调用其块内语句时,当第一个语句完成后,父线程才继续执行,其它停顿的线程也得以继续。
fork…join:所有语句块都执行完后才能继续块后续的处理。
fork…join_any:当第一个语句(所有进程中运行最快的一个)完成后,父进程才继续执行。
fork…join_none:父进程与其同时执行。
begin…end:顺序执行,通常有嵌套在fork语句当中。
在类中创建线程,使用fork…join_none可以开启一个线程。
线程中的自动变量:在fork…join_none语句中使用自动变量来保存变量的拷贝。
当你使用循环来创建线程时,如果在进入下一轮循环之前没有保存变量值,便会碰