麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

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

uvm_object的理解

2019-11-10 20:04:49
字體:
供稿:網(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í)搞不懂后面再說還有很多函數(shù)packPRintcopyclonerecord之類的先看uvm class reference文檔再結(jié)合代碼理解

這里寫圖片描述

typedef class

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

函數(shù)new

相關(guān)源代碼:

static protected int m_inst_count; //m是member,成員的意思吧。類實(shí)例化的個(gè)數(shù)。local int m_inst_id; //類實(shí)例化的id。跟類實(shí)例化個(gè)數(shù)有關(guān)系,比如類實(shí)例化3個(gè),則類實(shí)例化的id為1,2,3local string m_leaf_name; //類的實(shí)例化名稱,是uvm樹形層次結(jié)構(gòu)的一個(gè)枝葉。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è)構(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)前類。理解這個(gè),需要了解成員變量和局部變量的區(qū)別。見下面介紹。//這里的意思,個(gè)人理解,是重新產(chǎn)生一個(gè)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、成員變量在整個(gè)類內(nèi)都有效,局部變量只在定義它的方法內(nèi)有效。3、成員變量又分為實(shí)例成員變量(實(shí)例變量)和類變量(靜態(tài)變量)。、4、如果局部變量的名字和成員變量的名字相同,則成員變量被隱藏,即這個(gè)成員變量在這個(gè)方法內(nèi)暫時(shí)失效。5、如果局部變量的名字和成員變量的名字相同,則成員變量被隱藏。這時(shí)如果想在該方法內(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)該是因?yàn)閡vm_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ù)名一樣時(shí),通過supper.函數(shù)名,調(diào)用基類中函數(shù)。Systemverilog中不允許supper.supper.new方式經(jīng)行多層調(diào)用。pure virtual function,在子類里定義這個(gè)函數(shù)。該類里,只聲明。static function,函數(shù)內(nèi)的變量,都是靜態(tài)變量。定義靜態(tài)函數(shù),意義是為了訪問一大堆靜態(tài)變量。

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

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é)合代碼理解。

有需要的時(shí)候,再看吧。


發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 竹内纱里奈和大战黑人 | 免费网址黄 | 啪啪毛片 | 91成人免费在线观看 | 亚州精品国产 | 精品亚洲综合 | 一本一本久久a久久精品综合小说 | 亚洲电影在线观看高清免费 | 精品国产一区二区三区久久久 | 91成人免费网站 | 久久久久亚洲美女啪啪 | 曰韩一级片 | 亚洲国产精品高潮呻吟久久 | 国产精品一区99 | 成人不卡在线观看 | 免费a级作爱片免费观看欧洲 | 成人444kkkk在线观看 | 成人在线视频免费 | 日本一区二区久久久 | 欧美日韩在线视频一区 | 欧美成人午夜一区二区三区 | 久久久成人999亚洲区美女 | 久久国产综合视频 | 在线看91 | 亚洲九草 | 欧美一级全黄 | xnxx 日本免费 | 欧美成人一级 | 国产精品免费久久久久久 | 在线观看中文字幕av | 91av日韩| 中国av免费在线观看 | 九一成人 | 欧美精品一区二区三区在线 | 91成人午夜性a一级毛片 | 精品成人在线观看 | 欧美另类69xxxxx 视频 | 国产成人精品视频在线 | 黄色网址进入 | 成人羞羞在线观看网站 | 一区二区三区视频在线 |