国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學(xué)院 > 開發(fā)設(shè)計 > 正文

uvm_object的理解

2019-11-10 17:53:53
字體:
供稿:網(wǎng)友

typedef class函數(shù)new變量use_uvm_seeding成員變量和局部變量的區(qū)別set_name get_name get_full_name上述函數(shù)有一些是virtual function還有一些是靜態(tài)函數(shù)上述函數(shù)有一些是與uvm_object_wraper有關(guān)屬于factory的范疇暫時搞不懂后面再說還有很多函數(shù)packPRintcopyclonerecord之類的先看uvm class reference文檔再結(jié)合代碼理解

這里寫圖片描述

typedef class

typedef class uvm_component; 表示uvm_object會使用到uvm_component類,但是uvm_component類還沒有定義。 不過,在uvm_object,暫時沒發(fā)現(xiàn)使用。所以,個人理解,這一句刪掉也沒關(guān)系。

函數(shù)new

相關(guān)源代碼:

static protected int m_inst_count; //m是member,成員的意思吧。類實(shí)例化的個數(shù)。local int m_inst_id; //類實(shí)例化的id。跟類實(shí)例化個數(shù)有關(guān)系,比如類實(shí)例化3個,則類實(shí)例化的id為1,2,3local string m_leaf_name; //類的實(shí)例化名稱,是uvm樹形層次結(jié)構(gòu)的一個枝葉。function uvm_object::new (string name=""); m_inst_id = m_inst_count++; m_leaf_name = name;endfunctionfunction int uvm_object::get_inst_count(); return m_inst_count;endfunctionfunction int uvm_object::get_inst_id(); return m_inst_id;endfunction

注意: 如果基類構(gòu)造函數(shù)new()有參數(shù),那么擴(kuò)展類,必須有一個構(gòu)造函數(shù),并在構(gòu)造函數(shù)的第一行調(diào)用基類的構(gòu)造函數(shù)。

Class basel Function new(input int var); this.var = var;//利用this關(guān)鍵詞,把new函數(shù)的參數(shù),傳遞給類成員變量。 endfunction endclassclass extended extends basel function new(input int var); super.new(var); endfunctionendclass

變量use_uvm_seeding

相關(guān)源代碼:

static bit use_uvm_seeding = 1; //靜態(tài)變量,所以systemverilog全部對象,都可以訪問它,可寫可讀。function void uvm_object::reseed (); if(use_uvm_seeding) this.srandom(uvm_create_random_seed(get_type_name(), get_full_name())); //類的方法,如果使用成員函數(shù)和成員變量的話,需要this關(guān)鍵詞定位為當(dāng)前類。理解這個,需要了解成員變量和局部變量的區(qū)別。見下面介紹。//這里的意思,個人理解,是重新產(chǎn)生一個uvm_object類的隨機(jī)種子,默認(rèn)隨機(jī)種子是與process進(jìn)程有關(guān)。endfunction

參考: 類聲明中的靜態(tài)方法,類的全范圍內(nèi)可以調(diào)用,也可以無創(chuàng)建對象的方式被訪問,不可以訪問非靜態(tài)的成員(屬性和其他方法); 不能聲明為virtual,聲明中不能使用this句柄; this指針,涉及類的屬性、變量參數(shù)、對象本地的變量參數(shù)或方法,應(yīng)用在非靜態(tài)方法中。

成員變量和局部變量的區(qū)別

1、成員變量和局部變更的類型可以是systemverilog中的任何一種數(shù)據(jù)類型.變量定義部分所定義的變更被稱為類的成員變量(類里的變量),在方法體中定義的變量和方法的參數(shù)被稱為局部變量(方法里的變量)。2、成員變量在整個類內(nèi)都有效,局部變量只在定義它的方法內(nèi)有效。3、成員變量又分為實(shí)例成員變量(實(shí)例變量)和類變量(靜態(tài)變量)。、4、如果局部變量的名字和成員變量的名字相同,則成員變量被隱藏,即這個成員變量在這個方法內(nèi)暫時失效。5、如果局部變量的名字和成員變量的名字相同,則成員變量被隱藏。這時如果想在該方法內(nèi)使用成員變量,必須使用關(guān)鍵字this.【如果是靜態(tài)成員變量,就不需要了。】

set_name get_name get_full_name

// get_name// --------function string uvm_object::get_name (); return m_leaf_name; //返回值是類的實(shí)例名稱endfunction// get_full_name// -------------function string uvm_object::get_full_name ();//本意是全層次結(jié)構(gòu)下的實(shí)例名稱。這里看來就是枝葉的實(shí)例名稱,沒有結(jié)構(gòu)層次。應(yīng)該是因為uvm_object沒有樹形結(jié)構(gòu)吧(uvm_component才有樹形結(jié)構(gòu))。 return get_name();endfunction// set_name// --------function void uvm_object::set_name (string name); m_leaf_name = name;//設(shè)置類的實(shí)例名稱,跟new設(shè)置實(shí)例名稱是一樣的作用。endfunction

上述函數(shù)有一些是virtual function,還有一些是靜態(tài)函數(shù)。

virtual function,這樣擴(kuò)展類中才可以重新定義。擴(kuò)展類中函數(shù),和基類中函數(shù)名一樣時,通過supper.函數(shù)名,調(diào)用基類中函數(shù)。Systemverilog中不允許supper.supper.new方式經(jīng)行多層調(diào)用。pure virtual function,在子類里定義這個函數(shù)。該類里,只聲明。static function,函數(shù)內(nèi)的變量,都是靜態(tài)變量。定義靜態(tài)函數(shù),意義是為了訪問一大堆靜態(tài)變量。

上述函數(shù),有一些是與uvm_object_wraper有關(guān),屬于factory的范疇,暫時搞不懂。后面再說。

function description
get_type Returns the type-proxy (wrapper) for this object.
get_object_type Returns the type-proxy (wrapper) for this object.
get_type_name This function returns the type name of the object, which is typically the type identifier enclosed in quotes.

還有很多函數(shù),pack、print、copy、clone、record之類的,先看uvm class reference文檔再結(jié)合代碼理解。

有需要的時候,再看吧。


發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 富顺县| 二手房| 苏尼特左旗| 宜章县| 兴隆县| 赞皇县| 彰武县| 股票| 黄冈市| 宜宾县| 屏东市| 元氏县| 湘潭市| 阿合奇县| 大邑县| 合阳县| 翁牛特旗| 贵溪市| 越西县| 鄂州市| 龙江县| 红河县| 莱芜市| 抚顺县| 沁阳市| 靖边县| 莆田市| 双辽市| 津市市| 阿鲁科尔沁旗| 斗六市| 临城县| 虞城县| 田东县| 辰溪县| 上高县| 双城市| 咸宁市| 察哈| 永丰县| 寿阳县|