当前位置: 首页 > news >正文

【Verilog】阻塞/非阻塞赋值

目录

阻塞赋值

非阻塞赋值

Verilog模块编码的8个原则


阻塞赋值

阻塞赋值使用的赋值运算符为“=”

阻塞赋值的过程是立刻执行的,即阻塞赋值运算符右侧表达式求值完后立刻会更新至运算符左侧,并且这个执行的过程不受其他语句执行的影响,其后的语句只有当前的赋值操作执行完成后才能顺利执行

非阻塞赋值

非阻塞赋值使用的赋值运算符为“<=”

非阻塞赋值执行过程为:当当前仿真时间槽(time-slot)开始分析计算获得右侧表达式的值,在当前时间槽执行结束时更新左侧表达式的值,在右侧表达式分析计算和左侧表达式被更新之前,任何其他事件都可以执行,同时也有可能修改已经计算完成的右侧表达式的值,即非阻塞赋值的过程不影响其他语句的执行

根据非阻塞赋值的特点,其赋值运算符左侧操作数只能作为寄存器类型,因此非阻塞赋值只能用于过程语句中(initial和always),不允许在连续赋值语句中使用非阻塞赋值

所谓阻塞的概念是指在同一个always块中,其后面的赋值语句从概念上是前一条赋值语句结束后开始赋值的

Verilog模块编码的8个原则

  • 时序电路建模时,用非阻塞赋值
  • 锁存器电路建模时,用非阻塞赋值
  • 用always块建立组合逻辑模型时,用阻塞赋值
  • 在同一个always块中建立时序和组合逻辑电路时,用非阻塞赋值
  • 在同一个always块中不要既用非阻塞赋值又用阻塞赋值
  • 不要在一个以上的always块中为同一个变量赋值
  • 用$strobe系统任务来显示用非阻塞赋值的变量值
  • 在赋值时不要使用#0延时

下面两段代码中in、q1、q2和q3的初值分别为0、1、2、3,那么经历1个时钟周期后,左侧q3的值和右侧q3的值分别变成了()

always@(posedge clk)begin

q1=in;

q2=q1;

q3=q2;

end

always@(posedge clk)begin

q1<=in;

q2<=q1;

q3<=q2;

end

A. 0、0

B. 0、3

C. 2、0

D. 0、2

D

“=”是阻塞赋值,当 clk 的上升沿到来时,in 的值赋给 q1,然后 q1 的值赋给 q2,然
后 q2 的值赋给 q3。最终结果 q3 等于 in 的值,为 0。“<=”是非阻塞赋值,当 clk 的上升沿
到来时,in 的值赋给 q1,同时 q1 的值赋给 q2,同时 q2 的值赋给 q3。最终结果 q3 等于 q2
的值,为 2
┌─────┐ in ──►│ D │──► q1 │ Q │──► q2 │ │──► q3 └──▲──┘ │ clk
┌─────┐ ┌─────┐ ┌─────┐ in ──►│ D Q │──►──►│ D Q │──►──►│ D Q │──► q3 │ │ q1 │ │ q2 │ │ └──▲──┘ └──▲──┘ └──▲──┘ │ clk │ clk │ clk └─────────────┴─────────────┘
http://www.jsqmd.com/news/622468/

相关文章:

  • 记一次综合型流量分析 | 添柴不加火拦
  • **Pandas实战进阶:用DataFrame的“变形术”解锁数据清洗与分析新姿势**在数
  • 告别马赛克!用PyTorch和ESRGAN亲手复活你的老照片(附完整代码与数据集处理技巧)
  • YOLO11新手入门:5分钟学会训练自己的目标检测模型
  • Keyviz:终极键鼠可视化工具,让你的操作清晰可见
  • 质量工程师首选丨DOE实验设计软件盘点:信创认证平台(选型指南) - 品牌排行榜
  • [第五空间 2021]WebFTP
  • Meta押注“超级智能”:Muse Spark横空出世,扎克伯格的AI翻身仗打响了
  • Trae与Gitee MCP无缝协作:AI编程工具链的智能化革命
  • 利用Python API高效批量获取ECMWF大气数据:从注册到自动化下载全流程
  • 如何在Flash退役时代依然畅玩经典游戏?CefFlashBrowser的3大核心功能解密
  • Elsevier审稿追踪插件:5分钟告别手动刷新,实现智能投稿监控
  • 2026 智能会议系统哪个品牌好?世邦通信成政企首选
  • 反垃圾邮件网关厂商排名:建议参考第三方独立测试报告而非单纯市场调研 - 品牌排行榜
  • 1.2 环境搭建与项目结构
  • E-Hentai-Downloader 终极指南:如何快速批量下载漫画并打包为ZIP文件
  • 狂揽四万星!换掉OpenClaw太爽了,五美元就能养个AI打工人
  • 斯坦福HumanPlus机器人核心技术解析:从HST强化学习框架到HIT模仿学习的实现路径
  • AppScan 常见安装与配置问题实战指南
  • 手机怎么把ChatGPT和Gemini对话导出 - DS随心转小程序
  • PHP 后端面试题整理
  • 【电路标准设计】VOOHU沃虎电子--SPE单对以太网标准电路参考
  • 泛化与适应能力局限:认知边界下的成长困局
  • 【词汇专栏】RAG:让 AI 学会“查完资料再说话“
  • QwQ-32B在Matlab科学计算中的应用
  • 拒绝拉伸与留白:鸿蒙折叠屏适配 Top4 体验优化场景(含三折屏适配)
  • 已绑定的京东E卡可以回收吗? - 京顺回收
  • 使用 C# 删除 PDF 中的数字签名牢
  • Qwen3-ASR-0.6B与CNN结合的音频分类实战
  • 拯救者笔记本终极控制指南:Lenovo Legion Toolkit完全掌控你的硬件