PGRData/Script/matrix/xcommon/XStack.lua

50 lines
890 B
Lua
Raw Permalink Normal View History

2024-09-01 20:49:41 +00:00
---@class XStack 栈
XStack = XClass(nil, "XStack")
function XStack:Ctor()
self:Clear()
end
function XStack:Clear()
self.__Container = {}
self.__EndIndex = 0
end
function XStack:IsEmpty()
return self.__EndIndex < 1
end
function XStack:Count()
return self.__EndIndex
end
function XStack:Push(element)
if not element then return end
local endIndex = self.__EndIndex + 1
self.__EndIndex = endIndex
self.__Container[endIndex] = element
end
function XStack:Pop()
if self:IsEmpty() then
self:Clear()
return
end
local endIndex = self.__EndIndex
local element = self.__Container[endIndex]
self.__EndIndex = endIndex - 1
self.__Container[endIndex] = nil
return element
end
2024-09-01 20:49:41 +00:00
function XStack:GetContainer()
return self.__Container
end
function XStack:Peek()
return self.__Container[self.__EndIndex]
end