what is oop

terminology

an example class

default methods for classes

static attibute

assigment and copying

inheritance

polymorphism


why oop?

1.    helps in creating and maintaining large testbench:

You can creat complex data types and tie them together with

the routines that work with them

2.increases productivity:

You can creat testbenches and system-level models at a more

abstract level by calling a routine to perform an action rather than toggling bits

You can work with transactions rather than signals transitions

3.Allows the Testbench to be reused

OOP decouples the testbench from design details make it more rebust and easier

to maintain and reuse


How should the data and code be brought tegother?

transactions


OOP Basics:Terminology

Blueprint for a house ===> Class

A compelet house     ====> Object

House Address          ====> Handle

Turn on/off swithes     =====> Methods

Light swithes             ======> Properties


verilog                 VS     OOP

Block definition     module                            class

Block  instance      instance                         object

Block  name          instance name                handle

Data Type             reg & wire                      properties & variables

Executable Code    behavioral blocks              Methods:functions

(always / initial)               and tasks

tasks / functions

communication         ports or cross-module    mailboxes/semaphores/calls

between blocks      task calls                       ……..


OOP:Your First Class

略。。。

BusTran b; <—Declare a handle that points to an object of the type BusTran .When a handle is declared it is initialized to null

b= new();<- call the new function to construct the BusTran object.

when you call new you are allocating a new block of

memory to store variable for that object

1.new allocates space for ButTran

2.Initialize the variable to their default value( 0 for 2state

and x for 4-state variables)

3.Return the address where the object is stored


how gettint a handle on objects?

how deallocating a handle on objects?

BusTran b1,b2; <-----declare a handle

b1 = new();      <-----allocate bustran object

b2 = b1;           <------

b1 = new();       <------allocate another buttran object

b2 = null;          <-------deallocate the second bustran object


How do I create a variable shared by all objects of a class,but not make it global?

static variable

1.The static variable is associted with the class definition , not the instantiated object

2.It is often used to store meta-data,such as number of  instances construncted

3.It is shared by all objects of that class

Using  the id field can help keep track of transactions as flow through test


class routines : tasks and functions


Using one class inside another class

mainly use a handle to an object

using hierarchical syntax

done for reuse and controll complexity


copy:object copy

1.shallow copy  ===> b2 = new()b1  copy的只是句柄,但b1 & b2 指向同一个空间

2.deep copy      ====b2  = copy(b1) copy之后,b1 & b2有独立的空间


Inheritance

1.易于debug

2.在以前的基础进行代码扩展,而不是修改以前的代码.

super.parent_method/property

Inheritance chain

1.base class can hold extended class handle

2.extended class cannot hold base handle,this fails because the base object is missing properties(variable)

that only exist in the extended class,such as bad_src in the following example

$cast(badtr,tr) ===>必须badtr tr的类型一致


Abstract Classes and Virtual Methods

1.virtual class

2.polymorphism

the oop term for multiple routines sharing a common name is “polymorphism”

polymorphism is realized by virtual method

always declare routines inside a class as virtual so that they can be redefine

in an extended class.This applies to all tasks and functions ,except the new

function.which is called when the object is constructed, and there is no way to extend it

virtual fucntion在run时实现,compile并不关注 (有绑定的意思)

new在compile时实现


parameterized classes

It is often useful to define a generic class whose objects can be

instantiated to have different array sizes or data types

1.The normal verilog parameter machanism is used to parameterize the calss

class vector #(int size = 1)

bit [size-1:0] a;

endclass

2.Instance of this class can then be instantiated like modules or interfaces

vecor #(.size(2)) vtwo;


Initializing class properties (new)

How does systemverilog know which new function to call?

it does that by looking at the type of handle(有的概念根据句柄所指向的对象类型比如通过句柄调用method)

systemverilog之OOP的更多相关文章

  1. systemverilog(3)之Randomize

    what to randomize? (1) primary input data <==one data (2)encapsulated input data <== muti grou ...

  2. SystemVerilog搭建APB_I2C IP 层次化验证平台

    一.前言 近期疫情严重,身为社畜的我只能在家中继续钻研技术了.之前写过一篇关于搭建FIFO验证平台的博文,利用SV的OOP特性对FIFO进行初步验证,但有很多不足之处,比如结构不够规范.验证组件类不独 ...

  3. SystemVerilog基本语法总结(下)

    2018年IC设计企业笔试题解析-(验证方向) 1.请简述:定宽数组,动态数组,关联数组,队列四种数据类型的各自特点.解析:(1)定宽数组:其宽度在声明的时候就指定了,故其宽度在编译时就确定了.(2) ...

  4. SystemVerilog基本语法总结(中)

    Systemverilog 语法总结(中) 上一个博客分享了SV基本的概念,这一博客继续分享,等下一个博客分享一个公司的验证的笔试题目. l 事件 背景: Verilog中当一个线程在一个事件上发生阻 ...

  5. 【原创】SystemVerilog中的多态和虚方法

    封装可以隐藏实现细节,使代码模块化,继承可以扩展已经存在的代码模块,目的都是为了代码重用.多态是为了实现接口的重用.在SystemVerilog中,子类和父类之间多个子程序使用同一个名字的现象称为Sy ...

  6. c#面向对象基础技能——学习笔记(二)基于OOP思想研究对象的【属性】

    字段(成员变量): 字段只能从对象中访问实例字段,无法直接从类中访问(换言之,不创建实例就不能访问),可以理解为:字段一般用在内部数据交互使用,当需要为外部提供数据时,(要优先使用自动实现的属性而不是 ...

  7. 一个简单oop的changeTab

    好多地方都会用到这样一个效果“点击tab切换内容页”,根据自己的想法实现了一下,写了个简单的插件.以前写代码都是标准的函数式编程,现在觉得面向对象编程看起来比较爽,并且更容易维护,于是就用oop的思想 ...

  8. Python OOP(面向对象编程)

    一OOP的作用 在Python中,类是面向对象设计(OOP)的主要工具.通过使用类这种工具,OOP可以: 1.分解代码,最小化代码的冗余. 2.通过定制现有的代码,来编写新的程序,而不用在原处进行修改 ...

  9. OOP,WEB开发实用小技巧

    偶然读到一篇博客,记录一下心得.这种设计对于新手来说一般是想不到的,它充分的发挥了OOP语言的特性,让代码专用而清爽.这是不是重构的思想呢? 我们在写业务层的时候,有很多方法是重复功能的,我们就可以使 ...

随机推荐

  1. Redis - Windows平台下怎么切换db并且清理数据

    Redis 本身支持16个数据库(0~15),通过 数据库id 设置,默认为0.在Windows平台下可以通过启动redis-cli.exe来进入客户端,客户端默认连接数据库0,在客户端里可以输入各种 ...

  2. shell学习(4)- awk

    简介 awk是一个强大的文本分析工具,相对于grep的查找,sed的编辑,awk在其对数据分析并生成报告时,显得尤为强大.简单来说awk就是把文件逐行的读入,以空格为默认分隔符将每行切片,切开的部分再 ...

  3. PAT甲级——1135 Is It A Red-Black Tree (30 分)

    我先在CSDN上面发表了同样的文章,见https://blog.csdn.net/weixin_44385565/article/details/88863693 排版比博客园要好一些.. 1135 ...

  4. 爬虫之图片懒加载技术、selenium和PhantomJS

    爬虫之图片懒加载技术.selenium和PhantomJS   图片懒加载 selenium phantomJs 谷歌无头浏览器 一.图片懒加载 什么是图片懒加载? 案例分析:抓取站长素材http:/ ...

  5. Codeforces Round #497 (Div. 2) C. Reorder the Array

    Bryce1010模板 http://codeforces.com/contest/1008/problems #include <bits/stdc++.h> using namespa ...

  6. PlSqlDev中执行INSERT SQL语句包含&符号导致数据异常

    在PLSQL Developer中执行Insert语句时提示如下信息: 当时未注意,直接点击OK按钮继续. 导入数据后查看发现部分数据中的参数丢失了一部分,呈以下规律: . 而正常应为: . 经询问大 ...

  7. morphia(6-1)-查询

    1.filter morphia语法: query.filter("price >=", 1000); mongodb语法: { price: { $gte: 1000 } ...

  8. Android studio 断点调试

          最近进行业务测试,总是被测试环境不稳定或者测试数据错误困扰,一有问题就去找开发,自己都觉得很烦,所以就自己学着调试起来,这样以后遇到问题就可以自己定位的更深入了.   1.确保连接设备且进 ...

  9. [转]Java8 lambda表达式及新特新

    分享自:Vincent package info.liuwenjun.test; import org.junit.Test; import java.util.*; import java.util ...

  10. 5个典型的JavaScript面试题

    在IT界,需要大量的 JavaScript 开发者.如果你的能力能够胜任这一角色,那么你将获得许多换工作和提高薪水的机会.但是在你被公司录取之前,你需要展现你的技术,以便通过面试环节.在这篇文章中,我 ...