验证环境常见问题总结(一) 头文件保护宏

昨天帮新人同事解决了一个文件编译的问题,在此做下记录

SV中提供了一种基于package生成编译单元的方式,通常用于将某一功能集中的uvc封装在一个package中,这样便于在其他环境中复用。

 

为了避免在文件中可能出现的多次重复包含同一头文件导致的编译失败,sv中也使用了头文件保护宏的方式,避免同一个类被多次声明产生编译错误。然而有的时候,由于验证人员的疏忽,在需要产生一个新的uvc的情况下,可能会采用copy代码的方式,从另一个相似的uvc来产生新的uvc,但是却忘记修改头文件的保护宏。这样就会导致在一个同时需要这两个uvc的验证环境中,因为头文件保护宏的相同,总会有一个uvc无法被环境吃进来,从而导致例化的时候失败,提示例化使用的名字不是一个有效的类名。然而在debug的时候发现,环境所需的文件列表里面明明是把两个uvc的filelist都吃进来了,但是却出现了无法识别类名的情况。原因就是因为在前一个宏定义有效之后,第二个类名uvc_name2就根本不会被声明,环境也就不知道uvc_name2是一个类,自然就是无效的。

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值