• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            劍孤寒的小站

            人生的價(jià)值不是用時(shí)間,而是用深度去衡量的!
            posts - 75, comments - 290, trackbacks - 0, articles - 0

            在Lua中使用List

            Posted on 2008-10-26 11:06 劍孤寒 閱讀(6820) 評論(0)  編輯 收藏 引用 所屬分類: Lua
            《在Lua中使用List 》
            轉(zhuǎn)載請注明出處:http://groups.google.com/group/jianguhan


            在《Programming in Lua》一書中提到了一個(gè)雙端隊(duì)列的實(shí)現(xiàn)方法,我把它拿來改進(jìn)了一下用在了我正在制作的一個(gè)RPG游戲里,用起覺得 來還不錯(cuò),加了一個(gè)GetSize()來取得List的大小,這個(gè)在游戲制作中用處還是很大的^_^

            源代碼如下:
            CList = class()

            function CList:ctor()
                    self.m_list = { first = 0, last = -1 }
            end

            function CList:PushFront(value)
                    local first = self.m_list.first - 1
                    self.m_list.first = first
                    self.m_list[first] = value
            end

            function CList:PushBack(value)
                    local last = self.m_list.last + 1
                    self.m_list.last = last
                    self.m_list[last] = value
            end

            function CList:PopFront()
                    local first = self.m_list.first
                    if first > self.m_list.last then return nil end
                    local value = self.m_list[first]
                    self.m_list[first] = nil
                    self.m_list.first = first + 1
                    return value
            end

            function CList:PopBack()
                    local last = self.m_list.last
                    if self.m_list.first > last then return nil end
                    local value = self.m_list[last]
                    self.m_list[last] = nil
                    self.m_list.last = last - 1
                    return value
            end

            function CList:GetSize()
                    if self.m_list.first > self.m_list.last then
                            return 0
                    else
                            return math.abs(self.m_list.last - self.m_list.first) + 1
                    end
            end

            在最前面的那句CList = class() 這里使用了云風(fēng)寫的一個(gè)class函數(shù)創(chuàng)建一個(gè)類,
            這個(gè)函數(shù)可以在云風(fēng)的博客上找到,為了方便起見我就在這里先抄一下了:

            local _class={}

            function class(super)
                    local class_type={}
                    class_type.ctor=false
                    class_type.super=super
                    class_type.new=function(...)
                                    local obj={}
                                    do
                                            local create
                                            create = function(c,...)
                                                    if c.super then
                                                            create(c.super,...)
                                                    end
                                                    if c.ctor then
                                                            c.ctor(obj,...)
                                                    end
                                            end

                                            create(class_type,...)
                                    end
                                    setmetatable(obj,{ __index=_class[class_type] })
                                    return obj
                            end
                    local vtbl={}
                    _class[class_type]=vtbl

                    setmetatable(class_type,{__newindex=
                            function(t,k,v)
                                    vtbl[k]=v
                            end
                    })

                    if super then
                            setmetatable(vtbl,{__index=
                                    function(t,k)
                                            local ret=_class[super][k]
                                            vtbl[k]=ret
                                            return ret
                                    end
                            })
                    end

                    return class_type
            end

            69国产成人综合久久精品| www.久久99| 亚洲?V乱码久久精品蜜桃 | www亚洲欲色成人久久精品| 久久久久人妻一区二区三区| 2021国内久久精品| 超级97碰碰碰碰久久久久最新| 天天综合久久一二三区| 欧美伊人久久大香线蕉综合| 欧洲人妻丰满av无码久久不卡| 久久亚洲AV成人出白浆无码国产 | 国产一区二区精品久久凹凸| 久久久久99精品成人片牛牛影视 | 久久99精品综合国产首页| 久久精品国产一区二区三区不卡| 久久中文字幕人妻熟av女| 久久九九亚洲精品| 久久这里只有精品视频99| 蜜臀av性久久久久蜜臀aⅴ麻豆 | 伊人久久精品影院| 久久99精品国产一区二区三区| 尹人香蕉久久99天天拍| 91久久精品91久久性色| 久久综合亚洲色HEZYO社区| 亚洲狠狠婷婷综合久久蜜芽| 久久天天躁狠狠躁夜夜av浪潮| 99久久无码一区人妻a黑| 久久99这里只有精品国产| 66精品综合久久久久久久| 99久久无码一区人妻a黑| 亚洲精品国产美女久久久| 久久久久av无码免费网| 久久婷婷五月综合色99啪ak| 色成年激情久久综合| 久久久久亚洲av无码专区喷水 | 国产成人精品久久| 久久综合给合久久国产免费| 欧美黑人激情性久久| 久久影视综合亚洲| 久久久久久毛片免费看 | 久久人妻少妇嫩草AV无码蜜桃|