队列(Queue)是SystemVerilog中一种常用的数据类型,用于存储和管理一组有序的元素。队列具有先进先出(FIFO)的特性,即先进入队列的元素将首先被取出。
在SystemVerilog中,可以使用关键字queue
来声明一个队列类型。下面是一个示例代码,展示了如何声明和使用一个队列:
module QueueExample;
// 声明一个32位宽度的整数队列
queue int myQueue[$];
initial begin
// 向队列中添加元素
myQueue.push_back(10);
myQueue.push_back(20);
myQueue.push_back(30);
// 访问队列中的元素
$display("队列中的元素个数:%0d", myQueue.num());
$display("队列中的第一个元素:%0d", myQueue[0]);
// 从队列中取出元素
int firstElement = myQueue.pop_front();
$display("取出的第一个元素:%0d", firstElement);
$display("队列中的元素个数:%0d", myQueue.num());
// 遍历队