OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 7850|回复: 2

[其他] verilog赋值问题,case语句内外对同一变量赋值

[复制链接]

5

主题

17

帖子

0

精华

初级会员

Rank: 2

积分
103
金钱
103
注册时间
2019-1-8
在线时间
30 小时
发表于 2021-4-14 22:06:53 | 显示全部楼层 |阅读模式
1金钱
本帖最后由 路人戊 于 2021-4-14 22:09 编辑

今天在看Verilog I2C驱动的代码时,看到这么一段代码,有点搞不懂了,为啥cnt在case语句内部和外部都赋了值,这样不会冲突吗?求教大佬解惑。
3687b1fb182de743caff4a877e7afcb.png


最佳答案

查看完整内容[请看2#楼]

可以的,以后面的赋值语句的优先级高,后面的满足就执行后面的,否则就执行前面的
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

2

主题

136

帖子

0

精华

高级会员

Rank: 4

积分
661
金钱
661
注册时间
2020-4-21
在线时间
85 小时
发表于 2021-4-14 22:06:54 | 显示全部楼层
可以的,以后面的赋值语句的优先级高,后面的满足就执行后面的,否则就执行前面的
回复

使用道具 举报

10

主题

3281

帖子

1

精华

论坛元老

Rank: 8Rank: 8

积分
8206
金钱
8206
注册时间
2020-5-11
在线时间
3700 小时
发表于 2021-4-15 11:18:44 | 显示全部楼层
和单片机C语言差不多啊,变量计数,在一定条件清0,当然可以两个地方对同一个变量赋值。
  1. else
  2. {
  3.         cnt=cnt+1;
  4.         switch(cur_state)
  5.         {
  6.                 case st_idle: cnt=0;   break;
  7.         }
  8. }
复制代码

专治疑难杂症
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2024-11-24 00:26

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表