Stacks
优质
小牛编辑
133浏览
2023-12-01
堆栈有时称为外部数据队列,但我们遵循常见用法并将其称为堆栈。 它是一块逻辑上在Rexx外部的内存块。 像push和queue这样的指令将数据放入堆栈,拉取和解析等指令从中提取数据。 排队的内置函数报告堆栈中有多少项。
我们来看一个堆栈的例子。
/* STACK: */
/* */
/* This program shows how to use the Rexx Stack as either a */
/* stack or a queue. */
do j = 1 to 3
push ‘Stack: line #’ || j
/* push 3 lines onto the stack */
end
do j = 1 to queued()
/* retrieve and display LIFO */
pull line
say line
end
do j = 1 to 3 queue ‘Queue: line #’ || j
/* queue 3 lines onto the stack */
end
do queued()
/* retrieve and display FIFO */
pull line
say line
end
exit 0
程序中的第一个do循环将三行数据放入堆栈。 它使用push指令来执行此操作。 我们对这些行进行编号,以便在以LIFO顺序检索它们时,它们的顺序是明显的。
通过推送指令放入堆栈的项目在LIFO订单中检索 -
do j = 1 to 3
push ‘Stack: line #’ || j /* push 3 lines onto the stack */
end
下一个代码块显示了使用排队的内置函数来发现堆栈上的行数,以及一个从堆栈中检索所有行的循环 -
do j = 1 to queued() /* retrieve and display LIFO */
pull line
say line
end
由于这三个项目是通过推送放在堆栈上的,因此它们是以LIFO顺序检索的。
上述程序的输出如下。
STACK: LINE #3
STACK: LINE #2
STACK: LINE #1