最近不断使用到systemverilog 语言编程中的队列语法。今天抽时间,尽肯能全的整理一下队列的相关用法,一是加固基础打牢,而是在代码编写过程中,提高代码水平。
队列是一种复合数据结构,可以用来存储多个数据的容器,但同时又拥有自己的优势特性。正如绿皮书所言,队列的引入,使得SV语言在建模时,更加灵活自如,它在功能上同时兼容了动态数组和链表。可以随意插入元素,可以随意弹出元素。另外,队列还提供了许多内建方法。队列不需要new 方式创建。
一 基本概念
队列声明和unpacked 数组是类似的,只是需要使用$符号来确定数组的大小。在队列中,下标0表示第一个元素,$表示最后一个entry。可以指定队列的长度,也可以不指定队列的长度。
bit    queue_1[$];     // queue of bits  (unbound queue)
int    queue_2[$];     // queue of int 
byte   queue_3[$:255]; // queue of byte (bounded queue with 256 entries)
string queue_4[$];     // queue of strings
队列的初始化不需要像数组那样在大括号前面加’
queue_1  = {0,1,2,3}; 
queue_4  = {“Red”,"Blue”,"Green”};
 
 






![[护网杯 2018]easy_tornado1](https://img-blog.csdnimg.cn/7d74e541d821473898cd24323f5e24da.png)












