[導(dǎo)讀]我們經(jīng)常遇到的問題就是:我應(yīng)該怎么加載我定義的class,是用import的方式還是`include的方式?為了解答這個問題,首先應(yīng)該對systemverilog的類型機制有更多的了解,特別是強弱類型轉(zhuǎn)換機制(strongandweaktyping)。在編程語言中,相反于在不同類...
我們經(jīng)常遇到的問題就是:我應(yīng)該怎么加載我定義的class,是用import的方式還是`include的方式?
為了解答這個問題,首先應(yīng)該對systemverilog的類型機制有更多的了解,特別是強弱類型轉(zhuǎn)換機制(strong and weak typing)。
在編程語言中,相反于在不同類型之間的顯式轉(zhuǎn)換,我們稱隱式或者臨時的轉(zhuǎn)換為弱類型轉(zhuǎn)換。舉個栗子,對于verilog的bit向量,或者integral類型,適當(dāng)?shù)卦黾踊蛘邷p小數(shù)值的位寬就是一種弱類型轉(zhuǎn)換。如果你將一個7bit的數(shù)據(jù)和一個8bit的數(shù)據(jù)相加,verilog會在7bit數(shù)據(jù)的最高位前面填充1bit的0,并且返回一個8bit的結(jié)果。相反,如果使用的是VHDL,你必須顯式地聲明7bit數(shù)前的1bit填充,或者將8bit的數(shù)截斷,因為你需要保證你的表達(dá)式的兩個數(shù)位寬相等。
除開極少數(shù)的例外,在systemverilog里面其它的類型轉(zhuǎn)換都遵守強類型轉(zhuǎn)換的規(guī)則。強類型轉(zhuǎn)換指的是在不同類型之間的顯式轉(zhuǎn)換或者強制類型轉(zhuǎn)換。理解systemverilog中的等價類型是理解使用import還是`include的關(guān)鍵。
除開繼承,systemverilog僅使用類型的名稱來判斷class是否是等價的。再舉個栗子,假設(shè)我定義class A和class B如下:class A; int i; endclass : A | class B; int i; endclass : B |
盡管它們的內(nèi)容結(jié)構(gòu)完全一樣,systemverilog還是會認(rèn)為這兩個class不是等價的,因為它們的class name不一樣。class name不僅僅只是只是A和B,它還包含了類定義時聲明的作用范圍。當(dāng)你在package內(nèi)定義了一個class,這個package的名字將會作為前綴添加在class name前面。package P; class A; int i; endclass : A A a1; endpackage : P | package Q; class A; int i; endclass : A A a1; endpackage : Q |
現(xiàn)在我們有了關(guān)于class A的兩個定義,一個叫P::A,另一個叫Q::A。因此變量P::a1和Q::a1是不同的類型。我們使用`include語句重寫上面的栗子,得到的結(jié)果仍然是一樣的——兩個不同的類定義。| File A.sv | File P.sv | File Q.sv |
class A; int i; endclass : A | package P; `include “A.sv" A a1; endpackage : P | package Q; `include “A.sv" A a1; endpackage : Q |
在package里面,采用`include的方式添加了class A的定義,但是這樣你得到的仍然是class A的兩種定義。`include只是文本的一種快捷復(fù)制粘貼方式而已。而采用import方式不會重復(fù)復(fù)制文本,它會擴大定義的作用范圍。| File A.sv | File P.sv | File R.sv | File S.sv |
class A; int i; endclass : A | package P; `include “A.sv" endpackage : P | package R; import P::A; A a1; endpackage : R | package S; import P::A; A a1; endpackage : S |
class A在package P里面聲明(有且僅有package P聲明了),因此變量R::a1和S::a1是同一種類型,都是P::A的類型。事實上class A通過`include的方式添加到package里面,這件事情只發(fā)生了一次,一旦`include進去的文本被展開,就和File A.sv沒有什么關(guān)系了。
當(dāng)你編譯時提示你類型不兼容時,盡管它們看起來似乎是一樣的。那么你就需要確認(rèn)類型作用的范圍。在module內(nèi)定義的class會把module例化名稱作為類型的前綴。所以相同的module例化多份,結(jié)果是會創(chuàng)建多個不同的class name,且全部不兼容。
本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
電感是導(dǎo)線內(nèi)通過交流電流時,在導(dǎo)線的內(nèi)部及其周圍產(chǎn)生交變磁通,導(dǎo)線的磁通量與生產(chǎn)此磁通的電流之比。電感器也叫電感線圈,是利用電磁感應(yīng)原理制成的,由導(dǎo)線在絕緣管上單層或多層繞制而成的,導(dǎo)線彼此互相絕緣,而絕緣管可以是空心的...
關(guān)鍵字:
電感
磁通量
電感器
根據(jù)交通運輸部水運科學(xué)研究院提出的智慧港口的概念,智慧港口是利用新一代信息技術(shù),將港口相關(guān)業(yè)務(wù)和管理創(chuàng)新深度融合,使港口更加集約、高效、便捷、安全、綠色,創(chuàng)新港口發(fā)展模式,實現(xiàn)港口科學(xué)可持續(xù)發(fā)展。
關(guān)鍵字:
智慧港口
信息技術(shù)
業(yè)務(wù)
近年來,世界主要汽車大國紛紛加強新能源汽車戰(zhàn)略謀劃、強化政策支持、完善產(chǎn)業(yè)布局,新能源汽車已成為全球汽車產(chǎn)業(yè)轉(zhuǎn)型發(fā)展的主要方向和促進世界經(jīng)濟持續(xù)增長的重要引擎。2021年,全國新能源汽車實現(xiàn)產(chǎn)量354.5萬輛,銷量352...
關(guān)鍵字:
新能源
汽車
引擎
2007-2021年,全球針狀焦行業(yè)專利申請人數(shù)量及專利申請量總體呈現(xiàn)增長態(tài)勢。雖然2021年全球針狀焦行業(yè)專利申請人數(shù)量及專利申請量有所下降,但是這兩大指標(biāo)數(shù)量仍較多。整體來看,全球針狀焦技術(shù)處于成長期。
關(guān)鍵字:
針狀焦行業(yè)
專利申請人
增長態(tài)勢
按企業(yè)主營業(yè)務(wù)類型分,我國智能家居行業(yè)競爭派系可分為傳統(tǒng)家電企業(yè)、互聯(lián)網(wǎng)企業(yè)以及其他企業(yè)三派。傳統(tǒng)家電企業(yè)代表有海爾智家、美的集團、格力電器等,具有供應(yīng)鏈和銷售渠道,制造能力和品牌優(yōu)勢突出;互聯(lián)網(wǎng)企業(yè)代表有小米集團、百度...
關(guān)鍵字:
智能家居
互聯(lián)網(wǎng)企業(yè)
供應(yīng)鏈
軍工電子是集紅外技術(shù)、激光技術(shù)、半導(dǎo)體及嵌入式技術(shù)與虛擬仿真技術(shù)為一體的綜合性軍工技術(shù)體系,是國防信息化建設(shè)的基石。軍工電子行業(yè)包含在軍工行業(yè)內(nèi),專注于軍工行業(yè)電子產(chǎn)品布局。根據(jù)其軍工產(chǎn)品的不同可分為衛(wèi)星導(dǎo)航、通信指揮、...
關(guān)鍵字:
軍工電子
嵌入式技術(shù)
信息化建設(shè)
我國汽車零配件行業(yè)細(xì)分種類眾多,從汽車零配件主要產(chǎn)品來看,發(fā)動機系統(tǒng)行業(yè)內(nèi)有濰柴動力、華域汽車等主要從業(yè)企業(yè);在車身零部件領(lǐng)域內(nèi),福耀玻璃、中策橡膠具有一定的規(guī)模優(yōu)勢;行駛系統(tǒng)領(lǐng)域內(nèi)有中策橡膠提供的輪胎以及華為等企業(yè)提供...
關(guān)鍵字:
汽車零配件
發(fā)動機
行駛系統(tǒng)
茶飲料是指以茶葉或茶葉的水提取液、濃縮液、茶粉(包括速溶茶粉、研磨茶粉)或直接以茶的鮮葉為原料添加或不添加食品原輔料和(或)食品添加劑,經(jīng)加工制成的液體飲料。根據(jù)國家標(biāo)準(zhǔn)《茶飲料(GB/T 21733-2008)》的規(guī)定...
關(guān)鍵字:
茶飲料
茶葉的水
食品添加劑
全球液壓行業(yè)專利技術(shù)在21世紀(jì)初得到初步發(fā)展,這一時期液壓專利申請人數(shù)量和申請量處于較低水平。2011-2012年,液壓行業(yè)專利技術(shù)的發(fā)展總體處于成長期,2012年以后中全球液壓行業(yè)專利技術(shù)申請量或申請人數(shù)量整體處于波動...
關(guān)鍵字:
液壓行業(yè)
專利授權(quán)
技術(shù)類型
從上市企業(yè)的總市值情況來看,2022年7月28日,中芯國際、紫光國微和韋爾股份總市值遙遙領(lǐng)先,中芯國際總市值達(dá)到3238.21億元,紫光國微總市值達(dá)到1358.77億元,韋爾股份總市值達(dá)到1277.07億元;其次是兆易創(chuàng)...
關(guān)鍵字:
上市企業(yè)
集成電路
行業(yè)
健康服務(wù)行業(yè)目前是我國重點發(fā)展的行業(yè)之一,上市公司分布在健康服務(wù)各產(chǎn)業(yè)鏈環(huán)節(jié)。上游上市公司主要包括各類醫(yī)藥公司、智慧服務(wù)提供商等。主要包括上海醫(yī)藥(601607)、潤達(dá)醫(yī)療(603108)、湯臣倍健(300146)等。中...
關(guān)鍵字:
健康服務(wù)
智慧服務(wù)
醫(yī)藥公司
通用異步收發(fā)傳輸器(Universal Asynchronous Receiver/Transmitter),通常稱作UATR,是一種串行、異步、全雙工的收發(fā)器。全雙工的UART支持同時雙向通信,是嵌入式系統(tǒng)必不可少的d...
關(guān)鍵字:
異步收發(fā)
傳輸器
嵌入式系統(tǒng)
機緣巧合最近接觸了一下瑞芯微的rk3568平臺,從拿到sdk到完整編譯跑起來,遇到了一些坑,分享給大家。
關(guān)鍵字:
瑞芯微
rk3568
sdk
最近在瀏覽星球主題的時候,發(fā)現(xiàn)一位球友打卡中斷了,就去關(guān)心了一下他(瞧我這該死的責(zé)任心??),結(jié)果被他反手就問了下面這個問題。
關(guān)鍵字:
中斷
Spring Boot
實戰(zhàn)項目
大廠人人都想去,但每年名額就那么多,不可能每個人都能有滿意的結(jié)果,都能上岸心儀的大廠,特別是今年形勢這么嚴(yán)峻的情形。所有,大廠可以沖!但是可以的話先盡力拿一個offer保底,不管是好西瓜還是爛西瓜,你至少應(yīng)該先有一個西瓜...
關(guān)鍵字:
秋招
春招
總結(jié)
你好,我是阿秀。如果不出意外的話,今年互聯(lián)網(wǎng)校招最卷的崗位應(yīng)該是Java后端這塊了。我有個朋友在長沙一家小公司做HR,他們公司體量很小,剛剛度過創(chuàng)業(yè)起步期,想在今年校招中招 5 個校招生好好培養(yǎng)培養(yǎng)。
關(guān)鍵字:
Java后端
公司
培養(yǎng)
阿秀一直強調(diào)過實習(xí)的重要性,很早以前就強調(diào)過,能去實習(xí)的機會一定要優(yōu)先去實習(xí),校招求職這塊實習(xí)的加分項很大。如果還是讀本科的話,更是如此了,要知道國內(nèi)讀研很多學(xué)校老師是不讓出去實習(xí)的,所以各位還在讀本科的學(xué)弟學(xué)妹,能去實...
關(guān)鍵字:
實習(xí)
校招
秋招
SWM32S單片機有1個SDIO接口,支持多媒體卡(MMC)、SD 存儲卡、SDIO 卡等設(shè)備,可以使用軟件方法或者 DMA 方法(SDIO 模塊內(nèi)部 DMA,與芯片 DMA 模塊無關(guān))進行數(shù)據(jù)傳輸。
關(guān)鍵字:
SWM32S單片機
SDIO
DMA
串口作為單片機開發(fā)的一個常用的外設(shè),應(yīng)用范圍非常廣。大部分時候,串口需要接收處理的數(shù)據(jù)長度是不定的。那么怎么才能判斷一幀數(shù)據(jù)是否結(jié)束呢,今天就以STM32單片機為例,介紹幾種接收不定長數(shù)據(jù)的方法。
關(guān)鍵字:
單片機
串口
STM32