Verilog系列:class中的属性不能随意赋值

不论是在进行设计还是构造验证环境,经常都需要对一些变量或者属性进行赋值操作,我们知道在过程性语句中可以对变量进行赋值操作,那么在类中是不是也可以直接对类的属性进行赋值操作呢?本文将以具体示例展示如何对类的属性成员进行赋值操作,以及一些常见的错误行为.

module中经常会在过程性语句或者连续赋值语句中对变量或者线网进行赋值,那么在类中是不是也可以直接对属性成员进行初始化呢?针对类中属性成员的初始化我们先看如下示例.

【示例】

【仿真结果】

编译报错!

示例中第9行在属性成员定义时可以对其进行初始化,虽然第10行实例化了pt,但是11行对pt的成员进行赋值操作编译时将会报错.那么如果除了在初始化时给属性成员具体数值以外就不能在类中改变属性成员的数值了吗?有些朋友可能认为可以模拟属性成员定义时指定初始值的方式,pt实例化时通过ptnew函数传递特定的值给pt的属性成员,如下例.

【示例】

【仿真结果】

这种在实例化时调用构造函数来改变属性成员确实可以,但是存在一个问题,如果语句的执行书序不同,其执行的结果可能不一样,特别是在构造函数的实参为其他属性成员时,具体留给大家实验.总之该方法不是一种推荐的方法.

【示例】

【仿真结果】

示例中,将具体的实例化放在new函数中进行,这样可以确保类在实例化时数值的确定性(具体new函数的执行可以参看"new的初始化顺序").这里只是为了示例,属性成员的值的改变不仅可以放在new函数中,也可以在其他方法中出现.文中第一个示例之所以不正确是因为类中只能存在两种的"东西":属性成员(一些变量的声明、初始化等)和方法成员(task或者function,类是一种类型的定义,其中不能包含直接任何赋值语句,那么,如果要改变属性成员的值只有两种途径

  • 属性成员初始化时指定,这样该属性成员将具有初始值,后续可以在具体的方法中记性更改;

  • 在类的方法(包括new)中,在具体类实例化时或者实例化后的方法中进行改变;

 

全部评论
学习学习,楼主很强
点赞 回复 分享
发布于 2022-10-01 16:07 陕西

相关推荐

评论
点赞
收藏
分享
牛客网
牛客企业服务