亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

uvm_object的理解

2019-11-10 20:04:49
字體:
來源:轉載
供稿:網友

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

這里寫圖片描述

typedef class

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

函數new

相關源代碼:

static protected int m_inst_count; //m是member,成員的意思吧。類實例化的個數。local int m_inst_id; //類實例化的id。跟類實例化個數有關系,比如類實例化3個,則類實例化的id為1,2,3local string m_leaf_name; //類的實例化名稱,是uvm樹形層次結構的一個枝葉。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

注意: 如果基類構造函數new()有參數,那么擴展類,必須有一個構造函數,并在構造函數的第一行調用基類的構造函數。

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

變量use_uvm_seeding

相關源代碼:

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

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

成員變量和局部變量的區別

1、成員變量和局部變更的類型可以是systemverilog中的任何一種數據類型.變量定義部分所定義的變更被稱為類的成員變量(類里的變量),在方法體中定義的變量和方法的參數被稱為局部變量(方法里的變量)。2、成員變量在整個類內都有效,局部變量只在定義它的方法內有效。3、成員變量又分為實例成員變量(實例變量)和類變量(靜態變量)。、4、如果局部變量的名字和成員變量的名字相同,則成員變量被隱藏,即這個成員變量在這個方法內暫時失效。5、如果局部變量的名字和成員變量的名字相同,則成員變量被隱藏。這時如果想在該方法內使用成員變量,必須使用關鍵字this.【如果是靜態成員變量,就不需要了?!?h1 id="setname-getname-getfullname">set_name get_name get_full_name// get_name// --------function string uvm_object::get_name (); return m_leaf_name; //返回值是類的實例名稱endfunction// get_full_name// -------------function string uvm_object::get_full_name ();//本意是全層次結構下的實例名稱。這里看來就是枝葉的實例名稱,沒有結構層次。應該是因為uvm_object沒有樹形結構吧(uvm_component才有樹形結構)。 return get_name();endfunction// set_name// --------function void uvm_object::set_name (string name); m_leaf_name = name;//設置類的實例名稱,跟new設置實例名稱是一樣的作用。endfunction

上述函數有一些是virtual function,還有一些是靜態函數。

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

上述函數,有一些是與uvm_object_wraper有關,屬于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.

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

有需要的時候,再看吧。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
97精品国产aⅴ7777| 在线观看久久久久久| 欧美一级在线亚洲天堂| 热久久免费国产视频| 精品国产一区二区三区久久狼5月| 国产精品视频99| 国产性猛交xxxx免费看久久| 精品国内亚洲在观看18黄| 亚洲一区二区三区视频播放| 亚洲美女精品久久| 国产精品入口夜色视频大尺度| 欧美肥臀大乳一区二区免费视频| 精品久久中文字幕| 91老司机精品视频| 91九色视频在线| 国产精品自产拍在线观| 亚洲欧美激情一区| 国产精品18久久久久久首页狼| 亚洲伊人成综合成人网| 亚洲男人天堂网站| 国产精品91久久| 8090成年在线看片午夜| 欧美精品少妇videofree| 欧美日韩激情美女| 亚洲国产91精品在线观看| 成人免费视频网| 色黄久久久久久| 2019av中文字幕| 色狠狠av一区二区三区香蕉蜜桃| 国产亚洲欧洲在线| 成人做爽爽免费视频| 久久综合电影一区| 国产精品成人免费电影| 日韩高清欧美高清| 国产极品jizzhd欧美| 一区二区av在线| 中文字幕一区二区三区电影| 国产综合色香蕉精品| 日韩av在线免费观看| 国产精品27p| 俺去亚洲欧洲欧美日韩| 精品久久久久久中文字幕| 亚洲韩国日本中文字幕| 亚洲色在线视频| 狠狠躁天天躁日日躁欧美| 欧洲成人性视频| 亚洲国产精品久久91精品| 在线播放国产一区中文字幕剧情欧美| 亚洲自拍偷拍一区| 久久这里有精品视频| 亚洲成人网在线观看| 精品香蕉一区二区三区| 国产一区二区三区视频在线观看| 久久九九热免费视频| 国产日韩精品电影| 久久男人av资源网站| 国产成人免费91av在线| 91超碰caoporn97人人| 亚洲国产成人爱av在线播放| 亚洲精品中文字幕有码专区| 国产综合在线观看视频| 亚洲女人天堂av| 欧美最近摘花xxxx摘花| 97视频在线观看亚洲| 97视频免费看| 国产综合香蕉五月婷在线| 欧美激情一级欧美精品| 国产精品一区=区| 亚洲精品国偷自产在线99热| 91精品视频免费| 日韩一区二区av| 欧美激情一二区| 色综合久久88| 国产精品爽爽ⅴa在线观看| 乱亲女秽乱长久久久| 狠狠色香婷婷久久亚洲精品| 亚洲影院高清在线| 欧美洲成人男女午夜视频| xxx成人少妇69| 一本一道久久a久久精品逆3p| 欧美电影免费观看电视剧大全| 久久精品精品电影网| 亚洲影院高清在线| 久久久精品在线观看| 中文字幕在线视频日韩| 色综合久综合久久综合久鬼88| 日韩大片免费观看视频播放| 国产在线精品一区免费香蕉| 国产精品色悠悠| 亚洲精品免费在线视频| 亚洲精品日产aⅴ| 精品福利在线看| 中文字幕亚洲图片| www.午夜精品| 国产日本欧美一区二区三区在线| 精品亚洲一区二区三区四区五区| 欧美野外猛男的大粗鳮| 亚洲tv在线观看| 在线播放日韩欧美| 上原亚衣av一区二区三区| 91久久久国产精品| 亚洲免费视频在线观看| 亚洲另类欧美自拍| 日本午夜人人精品| 欧美在线精品免播放器视频| 日韩精品中文字幕在线播放| 久久亚洲春色中文字幕| 亚洲精品自产拍| 亚洲精品电影网在线观看| 久久精品国产电影| 欧美激情视频一区| 久久av红桃一区二区小说| 亚洲人永久免费| 欧美人与性动交a欧美精品| 亚洲图片制服诱惑| 国产精品免费观看在线| 欧美黑人性生活视频| 国产精品高潮呻吟久久av野狼| 国产精品96久久久久久| 久久69精品久久久久久国产越南| 欧美成人免费va影院高清| 国产精品久久精品| 欧美最顶级丰满的aⅴ艳星| 这里只有精品视频在线| 91黑丝在线观看| 亚洲欧美中文字幕在线一区| 欧美亚洲国产日韩2020| 97超级碰在线看视频免费在线看| 日韩av黄色在线观看| 欧美色视频日本版| 国产激情久久久久| 中文字幕日韩欧美精品在线观看| 国产精品午夜视频| 日韩av资源在线播放| 久久久久久高潮国产精品视| 91sao在线观看国产| 欧美日韩性视频| 亚洲综合最新在线| 国产精品影片在线观看| 亚洲第一视频网站| 久久这里有精品视频| 欧美亚洲在线播放| 久久久久北条麻妃免费看| 中文字幕亚洲欧美一区二区三区| 国产精品入口尤物| 欧美在线视频导航| 777国产偷窥盗摄精品视频| 青青在线视频一区二区三区| 国产成人精品视频在线| 国产ts人妖一区二区三区| 精品久久久久人成| 韩国19禁主播vip福利视频| 亚洲在线免费看| 亚洲国产精品va在看黑人| 日韩精品免费在线观看| 欧美中文在线观看| 日韩av三级在线观看| 久久免费视频网| 欧美亚洲在线观看| 国产亚洲成精品久久| 亚洲国产欧美一区二区丝袜黑人| 亚洲午夜精品久久久久久性色| 97碰碰碰免费色视频| 欧美又大粗又爽又黄大片视频|