[UVM源代码研究] 如何定制一款个性化的打印格式
文章总结:定制UVM的打印格式并非直接使用默认设置,而是源码印源涉及到UVM类库的深入理解。首先,打印m打`uvm_info`等宏的源码印源执行过程实际上是通过`uvm_report_enabled`函数,这个函数实际调用的打印m打是uvm_root的单例模式下的uvm_report_object的uvm_report_enabled方法,因为uvm_root支持这种模式。源码印源站内图片搜索源码宏中的打印m打verbosity值会与预设阈值进行比较,同时还会检查action设置,源码印源以决定是打印m打否执行打印。打印格式的源码印源定制关键在于`compose_message`函数,它由uvm_report_server类定义,打印m打可以通过继承并重写此函数来自定义输出格式,源码印源比如使用`__FILE__`和`__LINE__`这些编译时指令。打印m打
实现个性化打印的源码印源步骤包括:创建一个自定义的report_server子类,重写`compose_message`函数,打印m打然后在测试环境中设置这个自定义的server。这样,无论执行`uvm_info`等宏,都会按照我们定制的格式显示,适用于所有四种severity(uvm_info/uvm_error/uvm_warning/uvm_fatal)。
通过上述方法,网页整套源码下载你就能为UVM的打印格式定制出符合自己需求的样式,让输出信息更加直观和易于理解。
[UVM源代码研究] UVM的field_automation实现的print()函数如何灵活控制打印数组元素的数量
实际工作中,我们常遇到需打印包含多个数组或队列元素的transaction时,仅默认显示开始5个和最后5个元素。若需查看更多元素值或完整内容,可考虑两种方法:一是重写transaction的do_print()函数,自定义打印内容与格式;二是探索现有UVM源代码,修改相关设定以实现打印更多元素。
首先,vue router 2.0 源码分析can_txrx_transfer的注册方式,发现其默认仅显示特定数量的元素。通过查看源代码,发现实现打印机制的关键在于UVM_FIELD_QDA_INT宏与UVM_FIELD_UTILS_BEGIN宏的结合,它们共同调用_m_uvm_field_automation函数,该函数根据指定的what_参数(如UVM_PRINT)调用相应的打印函数。
在调用print()函数时,最终调用_m_uvm_field_automation,进一步调用uvm_print_array_int3宏。该宏通过uvm_print_qda_int4宏实现打印逻辑,源码之家php游戏对静态或动态数组、队列元素的打印格式进行统一处理。在uvm_print_qda_int4宏中,定义了uvm_printer与uvm_printer_knobs变量,用于接收打印参数与配置信息。
uvm_default_printer作为全局变量,其配置决定了打印格式。在打印数组时,通过设置uvm_printer_knobs中的begin_elements与end_elements变量,可以灵活控制打印元素的android am命令源码数量。具体配置方法可将uvm_default_printer配置在test_base的build_phase中,实现对打印数量的精确控制。
通过上述分析,我们了解了UVM源代码实现打印机制的原理,并掌握灵活配置数组/队列元素打印数量的方法。这种方法不仅提供了更为灵活的打印控制,还能根据实际需求调整打印内容与格式,增强代码的可读性和实用性。
如何在博途软件中打印出程序的源代码?
博途软件可以将程序导出到Word文档中,具体操作可以按照以下步骤进行:
1. 打开博途软件,打开需要导出的程序。
2. 在程序编辑页面中,选择菜单栏中的“文件”-“导出”-“导出为Word文档”。
3. 在弹出的导出对话框中,可以选择导出内容的范围和格式。
4. 如果需要导出程序的注释和说明,可以勾选“导出注释”和“导出说明”选项。
5. 点击“导出”按钮,选择保存的路径和文件名,并点击“保存”按钮即可。
6. 导出完成后,可以在保存的路径中找到导出的Word文档,打开查看。
需要注意的是,导出的Word文档中包含了程序的源代码、注释和说明,如果需要保护程序的机密性,可以考虑在导出前对程序进行加密或者删除敏感信息。此外,导出的Word文档中可能会存在格式和排版问题,需要根据需要进行调整和修改。
1
在项目树中选择工程项目
2
菜单“项目”--打印,打印机/文档布局/属性,选项如下
3
点击“打印 ”,弹出对话框,选择保存路径,填写文件名,点击“保存”
4
如果页数较多,请内心等待,最终保存如下
2024-11-20 21:05
2024-11-20 19:48
2024-11-20 19:27
2024-11-20 19:23
2024-11-20 19:16