systemverilog语法(七)

十七、线程
线程的量级比进程小,其代码和存储区可共享,而且所消耗的资源比典型的进程小的多。
1、 线程的使用
1) begin ••••end顺序执行、fork•••join并行执行
2) fork•••join、fork•••join_none、fork••••join_any的区别
这里写图片描述
注意:1)fork•••join_none块后的那个语句执行早于fork_none内的任何语句。
3) fork•••join_any块对块内语句进行调度,当完成第一个语句后,父线程才继续执行,其他停顿线程也得继续执行。
2、 等待所有的衍生线程
可以通过wait fork语句来等待所有子线程结束
例: 这里写图片描述

3、 在线程间共享变量
避免使用全局变量,这样容易导致漏洞。
4、 停止线程的方法
使用disable语句可以用于停止systemverilog中的线程
停止单个线程:例
这里写图片描述
停止多个线程,例:
这里写图片描述

十八、线程间的通信
1、 事件
1)在事件边沿阻塞:例
这里写图片描述
其输出结果如下:
这里写图片描述
2)等待事件的边缘触发方法
这里写图片描述
4) 传递事件
这里写图片描述
2、 旗语的使用方法
New方法可以创建一个带当个或多个钥匙的旗语,使用get可以获取一个或多个钥匙,而put则可以返回一个或多个钥匙,如果试图获取一个旗语而不希望被阻塞,可以使用try_get()函数
例:
这里写图片描述
如果需要使用带多个钥匙的旗语,需要注意:1)你返回的钥匙可以比你取出来的多。2)当你的测试程序需要获取和返回多个钥匙时,务必谨慎。
3、 信箱的使用方法
两个线程之间传递信息可以通过信箱。信箱可以简单的理解为一个具有源端和收端的fifo。
信箱是一种对象,必须调用new函数来进行实例化
使用put任务可以把数据放入信箱里,而使用get任务则可以移除数据。如果信箱为满,则put会阻塞;如果为空,则get会阻塞。Peek任务可以获取对信箱里数据的拷贝而不移除它。
注意:可以在信箱中放入句柄,但不能是对象。务必在一个信箱里只放入一种类型的数据。
创建多个对象的发生器的正确方法:例
这里写图片描述
接收信箱的事务驱动器:例
这里写图片描述
使用信箱实现对象的交换,例:
这里写图片描述
使用信箱和事件来实现线程同步的方法:
这里写图片描述
这里写图片描述
输出结果为:
这里写图片描述

  • 15
    点赞
  • 78
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
SystemVerilog是一种硬件描述语言(HDL),用于描述数字电路的行为和结构。它是Verilog语言的扩展,引入了许多新的特性和语法。 以下是SystemVerilog的一些基础语法: 1. 模块定义:使用`module`关键字定义模块,模块是SystemVerilog中的基本构建单元。例如: ``` module MyModule(input wire clk, input wire rst, output reg data); // 模块内部逻辑 endmodule ``` 2. 端口声明:模块的输入输出端口使用`input`和`output`关键字声明,可以使用`wire`或`reg`类型进行声明。例如: ``` input wire clk; // 输入端口 input wire rst; output reg data; // 输出端口 ``` 3. 数据类型:SystemVerilog支持多种数据类型,包括整数、浮点数、位向量、数组等。例如: ``` int a; // 整数类型 real b; // 浮点数类型 bit [7:0] c; // 8位位向量类型 reg [3:0] d; // 4位寄存器类型 int e [3:0]; // 整数数组类型 ``` 4. 运算符:SystemVerilog支持常见的运算符,包括算术运算符、逻辑运算符、位运算符等。例如: ``` a = b + c; // 加法 d = a & b; // 位与 e = (a > b) ? c : d; // 条件运算符 ``` 5. 控制语句:SystemVerilog支持常见的控制语句,如条件语句、循环语句等。例如: ``` if (a > b) begin // 执行语句 end else if (a < b) begin // 执行语句 end else begin // 执行语句 end for (int i = 0; i < 10; i++) begin // 循环体语句 end while (condition) begin // 循环体语句 end ``` 这些是SystemVerilog的一些基础语法,还有其他更高级的特性和语法可以用于描述复杂的数字电路。希望这些信息对你有帮助!如果你还有其他问题,请继续提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

南国之邱

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值