首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >将整个寄存器数组设置为零

将整个寄存器数组设置为零
EN

Stack Overflow用户
提问于 2020-02-14 02:16:07
回答 3查看 404关注 0票数 0

我想将数组中的所有寄存器设置为零。但是,我已经参数化了数组的大小:

代码语言:javascript
复制
logic [WIDTH-2:0] numelem [0:MAXBITS-1];

有没有一种方法,我基本上可以做numelem <= {0,0,0,0,...},但对于通用的大小?该方法最好是非阻塞的,因为我需要在always_ff块中进行赋值。谢谢。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2020-02-14 02:42:47

有几种方法可以实现这一点:

1)按照Oldfart的建议,使用for循环;它简单易懂

代码语言:javascript
复制
int i;
...
for (i = 0; i < MAXBITS; i = i + 1) begin
  numelem[i] <= '0;
end

2)使用带有default关键字的数组赋值模式:

代码语言:javascript
复制
numelem <= '{default: '0};

3)如果不需要模拟'bx'bz状态,请使用bit类型,而不是logic类型;bit类型的变量被初始化为'b0,而不是'bx

票数 3
EN

Stack Overflow用户

发布于 2020-02-14 02:31:57

我赞成使用老式的for循环:

代码语言:javascript
复制
int c;
   ...
   for (c=0; c<MAXBITS; c=c+1) numelem [c] <= 'b0;
票数 1
EN

Stack Overflow用户

发布于 2020-02-14 15:28:38

代码语言:javascript
复制
logic [WIDTH-2:0] numelem [0:MAXBITS-1] = '{default:'0};
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/60214186

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档