ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

SystemVerilog中类的五要素以及句柄、new函数作用的形象理解,函数返回值

2022-09-16 05:30:56  阅读:287  来源: 互联网

标签:Transaction 函数 句柄 tr 返回值 new SystemVerilog 变量


转自:原文链接:https://blog.csdn.net/dinghj3/article/details/116583131

刚开始学面向对象编程OOP时都会有点难以接受,但我们可以通过形象的类比来解决这个问题。
在这里插入图片描述

类 class——相当于我们要盖房的图纸,有了这个图纸,我们就能盖出一堆结构类似的楼房;
对象 object——可以理解为房子本身,这是我们根据图纸建起来的;
句柄 handle——房子的地址,门牌号,一个门牌号对应着一个房子,你可以通过门牌号来找到你想找的房子。用专业的话讲,就是句柄是对象的指针,我们通过句柄来找到对应的对象;
变量 properties(也叫属性)——是房子里面的东西。我们知道,房子里可以有很多东西,也就对应着对象可以有多个变量。比如灯就是房子里的东西之一。我们可以通过灯的开关来调节房子的亮暗。
方法 methods——用来操作变量的一段代码。如果这个变量是灯的话,那么这段代码对应的就是开灯和关灯两个动作。

下面再通过一段代码来聊一下句柄的声明以及new函数的形象理解。

class Transaction;
//变量
...
//方法
endclass:Transaction

Transaction tr;
tr = new();
class Transaction;
//变量
...
//方法
endclass:Transaction

Transaction tr;
tr = new();

我们先是定义了一个类,叫做Transaction。endclass后面的:Transaction最好加上,方便在你识别了很多个类之后一眼看出边界。

Transaction tr;//声明了一个句柄,叫tr
tr = new();//创建了对象

接下来的这两句的作用分别是声明了一个叫tr的句柄,以及用new函数创建了一个对象。其中,tr = new()的作用有三点:

例化(创建)对象,也就是申请新的内存块来保存对象的变量
初始化变量(二值→0;四值→x)
返回句柄

用更通俗易懂的话来解释上面这两句。
Transaction tr; 我通过这一句声明了一个句柄,就类似于我指着xx村xx路xx号这个地址,说我准备要在这个地方盖房子了。

而new函数的三个作用分别可这样理解。

创建对象,申请新内存——我清理出了一块空地,并把房子给盖好了;
初始化——我把某个品牌的洗衣机、电饭煲、灯什么的搬进去里面,新房子就有了;
返回句柄给tr——房子弄好了,很开心,很欢迎朋友们来参观一下,不然我累了这么久岂不是白忙活了?所以我把房子的地址(句柄tr)发在了好朋友的群聊里,之后他们就可以凭这个地址来我家玩了!他们可以用电饭煲煮香喷喷的米饭,家里的洗衣机也可以随便用哈哈。

new[ ]是用来设置动态数组大小的。new( )和new[ ]都是用来申请内存并初始化变量。两者最大的不同在于调用new( )函数仅创建了一个对象,而new[ ]操作则建立一个含有多个元素的数组。new( ) 可以使用参数设置对象的数值,而new[ ]只需使用一个数值来设置数组的大小。

关于函数返回值

简单的说,函数就是一个算法,有不有返回值是跟这个函数做什么的有关系。
一般情况下,求和这类的就要返回值,比如
int add(int a,int b)
{
return a+b;//这就返回a+b的和,用函数的时候,你只要传a,b的值就得了
}
用的时候这样:
int s=add(100,200); //就把100+200也就是300的值赋给s了
这种情况就是相当于你去A地做买东西,你肯定得拿东西回来。你拿回来的东西也就是返回值

还有些不用返回值的,比如,输出,或者给有地址的变量赋值等 这些函数前面就可以用void 表示无返回值,当然你也可以返回你想返回的。比如说成功或者失败返回true or false.也可以随意返回一个int型的 1或者0
比如:
void pri(int i)
{
printf("%d",i);//这个就是打印一个整型的i出来
}
这种就像你去A地不干什么,就去那儿吼两句,也就不用拿什么回来了。
还有种给有地址的变量赋值。那就相当于你去a地寄了一封信,也不用什么什么回来。

啊,打得手累,我就这样理解了。给是清楚点了,呵呵
例如你要计算5+3=?,这个就需要返回值啦,但你要是排列字符之类的,就不需要返回值,因为它是对字符进行操作,没有数字。
————————————————
版权声明:本文为CSDN博主「Hardworking_IC_boy」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/dinghj3/article/details/116583131

标签:Transaction,函数,句柄,tr,返回值,new,SystemVerilog,变量
来源: https://www.cnblogs.com/Algo-Goer/p/16698566.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有