说说$strobe,$monitor 和 $display 的差别

本文介绍了Verilog中$display,$strobe及$monitor系统任务的使用方法。$display用于显示变量值,$strobe用于非阻塞性赋值变量显示,而$monitor则持续监控并输出指定信号的变化。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

verilog使用$display,$strobe系统任务来打印log。

  • 用$display()系统任务来显示当前变量的值。
  • 用$strobe()系统任务来显示用非阻塞赋值的变量值。
  • 用$monitor()监控和输出参数列表中的表达式或变量值。
$display,$strobe()

$monitor()

当启动一个带有一个或多个参数的$monitor任务时,仿真器则建立一个处理机制,使得每当参数列表中变量或表达式的值发生变化时,整个参数列表中变量或表达式的值都将输出显示。

例如:

$monitor($time,,"rxd=%b txd=%b",rxd,txd)。括号内的变量均为参数列表。

在多模块调试的情况下,许多模块中都调用了$monitor,因为任何时刻只能有一个$monitor起作用,因此需配合$monitoron与$monitoroff使用,把需要监视的模块用$monitoron打开,在监视完毕后及时用$monitoroff关闭,以便把$monitor 让给其他模块使用。$monitor与$display的不同处还在于$monitor往往在initial块中调用,只要不调用$monitoroff,$monitor便不间断地对所设定的信号进行监视。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值