• <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>
            Cpper
            C/C++高級(jí)工程師 Android高級(jí)軟件工程師 IT集成工程師 音頻工程師 熟悉c,c++,java,c#,py,js,asp等多種語言 程序猿
            順手翻了下3d游戲引擎設(shè)計(jì)實(shí)時(shí)計(jì)算機(jī)圖形學(xué)的應(yīng)用方法這本書(英文本第二版)
            在其800page.18.4章的
            template<class T>
            class Stack中這兒有一個(gè)小錯(cuò)誤
            就是
            在函數(shù)
            bool Push..
            中間 其判斷條件是錯(cuò)誤的
            對(duì)于這個(gè)類模板
            我把它成了了蓋莫引擎死板的風(fēng)格
            如下:
            ///////////////////////////////////////////////////////////
            /// 定義引擎棧模板類
            ///////////////////////////////////////////////////////////
            template<class T>
            class Stack : NonCopyable
            {
            public:
                
            ///////////////////////////////////////////////////////
                
            /// 構(gòu)造,析構(gòu)棧模板
                
            ///////////////////////////////////////////////////////
                Stack(int maxsize);
                
            ~Stack();
            public:     
                
            ///////////////////////////////////////////////////////
                
            /// 數(shù)據(jù)入棧
                
            ///////////////////////////////////////////////////////
                bool Push(const T& element);
                
                
            ///////////////////////////////////////////////////////
                
            /// 數(shù)據(jù)出棧
                
            ///////////////////////////////////////////////////////    
                bool Pop(T& element);
                
                
            //////////////////////////////////////////////////////////
                
            /// 獲取棧頂元素
                
            //////////////////////////////////////////////////////////     
                bool GetTop(T& element)const;
                            
                
            ///////////////////////////////////////////////////////
                
            /// 檢查棧是否為空棧,滿棧
                
            ///////////////////////////////////////////////////////    
                bool IsEmpty()const;
                
            bool IsFull()const;
            private:
                
            int  maxsize;
                
            int  top;
                T
            *   data;    
            };

            #include 
            <GEngine/Template/Stack.inl>
            in stack.inl
            ///////////////////////////////////////////////////////
            /// 構(gòu)造,析構(gòu)棧模板
            ///////////////////////////////////////////////////////
            template<class T>
            Stack
            <T>::Stack(int maxsize):
            top(
            -1)
            {
                ASSERT(maxsize 
            > 0);
                
            this->maxsize = maxsize;
                data 
            = new T[this->maxsize];    
            }

            template
            <class T>
            Stack
            <T>::~Stack()
            {
                CHECK_PTR_ARRAY_AND_DELETE(data);
            }
                 
            ///////////////////////////////////////////////////////
            /// 數(shù)據(jù)入棧
            ///////////////////////////////////////////////////////
            template<class T>
            inline 
            bool Stack<T>::Push(const T& element)
            {
                
            if(top < maxsize-1)
                {
                    data[
            ++top] = element;
                    
            return true
                }
                
            return false;
            }
                
            ///////////////////////////////////////////////////////
            /// 數(shù)據(jù)出棧
            ///////////////////////////////////////////////////////    
            template<class T>
            inline 
            bool Stack<T>::Pop(T& element)
            {
                
            if(top >=0)
                {
                    element 
            = data[top--];
                    
            return true;
                }
                
            return false;
            }
                
            //////////////////////////////////////////////////////////
            /// 獲取棧頂元素
            //////////////////////////////////////////////////////////     
            template<class T>
            inline 
            bool Stack<T>::GetTop(T& element)const
            {
                
            if(top >= 0)
                {
                    element 
            = data[top];
                    
            return true
                }
                
            return false;
            }
                            
            ///////////////////////////////////////////////////////
            /// 檢查棧是否為空棧,滿棧
            ///////////////////////////////////////////////////////    
            template<class T>
            inline 
            bool Stack<T>::IsEmpty()const
            {
                
            return top == -1;
            }

            template
            <class T>
            inline 
            bool Stack<T>::IsFull()const
            {
                
            return top == maxsize-1;
            }
                
                
                
                
                
                

            posted on 2010-04-23 19:11 ccsdu2009 閱讀(387) 評(píng)論(0)  編輯 收藏 引用

            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


             
            午夜精品久久久久久中宇| 久久本道久久综合伊人| 无码人妻精品一区二区三区久久| 一本大道久久香蕉成人网| 久久久久久伊人高潮影院| 久久伊人精品青青草原高清| 久久久WWW免费人成精品| 亚洲伊人久久大香线蕉综合图片| 久久国产精品99久久久久久老狼| 久久精品国产一区二区三区 | 亚洲精品无码久久千人斩| 亚洲乱亚洲乱淫久久| 亚洲中文久久精品无码ww16| 久久99久久成人免费播放| 久久99精品久久久久婷婷| 97精品伊人久久大香线蕉| 精品久久久久中文字| 日本久久久久亚洲中字幕| 久久午夜夜伦鲁鲁片免费无码影视| 国产精品18久久久久久vr| 久久妇女高潮几次MBA| 日本高清无卡码一区二区久久 | www.久久99| 久久综合九色综合网站| 综合人妻久久一区二区精品| 久久国产免费直播| 久久se精品一区二区影院| 国产伊人久久| 欧美成a人片免费看久久| 国产精品xxxx国产喷水亚洲国产精品无码久久一区 | 国产精品久久久久蜜芽| 日韩亚洲国产综合久久久| 亚洲国产成人久久笫一页| 久久亚洲2019中文字幕| 久久久国产精华液| 亚洲精品tv久久久久| 国产精品久久久久久久久久影院| 无码人妻久久一区二区三区蜜桃| 久久亚洲sm情趣捆绑调教| 欧美丰满熟妇BBB久久久| 99久久99久久久精品齐齐|