找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 4271|回復(fù): 1
打印 上一主題 下一主題
收起左側(cè)

Verilog中阻塞賦值和非阻塞賦值的正確使用

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:72008 發(fā)表于 2015-1-12 02:10 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
Verilog中有兩種為變量賦值的方法。一種叫做連續(xù)賦值,另一種叫做過程賦值。
    過程賦值又分為阻塞賦值和非阻塞賦值。
    阻塞性賦值使用“=”為變量賦值,在賦值結(jié)束前不可以進(jìn)行其他操作,在賦值結(jié)束之后繼續(xù)后面的操作。這個過程就好像阻斷了程序的運行。
    非阻塞賦值使用“<=”為變量賦值,在執(zhí)行賦值語句時,僅僅對“<=”右邊的值進(jìn)行評估,但并不馬上執(zhí)行賦值,然后繼續(xù)執(zhí)行后面的操作。這個過程就好像沒有阻斷程序的運行。
    多條阻塞賦值語句是順序執(zhí)行的,而多條非阻塞賦值是并行進(jìn)行的,這就是兩者的區(qū)別。
    堅持做到以下列出的注意事項,就可以基本上避免使用阻塞賦值和非阻塞賦值不當(dāng)引起的錯誤。
    1.在使用always塊描述組合邏輯時,使用阻塞賦值;在使用always塊描述時序邏輯時,使用費阻塞賦值。
    2.不要在同一個always塊內(nèi)同時使用阻塞賦值和非阻塞賦值。
    3.無論是使用阻塞賦值還是使用非阻塞賦值,不要再不同的always塊內(nèi)為同一個變量賦值。
    4.在程序中不要使用0延時。

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復(fù)

使用道具 舉報

沙發(fā)
ID:83553 發(fā)表于 2016-3-7 22:44 | 只看該作者
4.在程序中不要使用0延時。
--------不解其意,請教樓主。
回復(fù)

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

手機版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機教程網(wǎng)

快速回復(fù) 返回頂部 返回列表