• <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>

            鍵盤上的舞者

            My Email: marckywu@gmail.com
            隨筆 - 19, 文章 - 0, 評論 - 3, 引用 - 0
            數據加載中……

            安全訪問數組的指針類模板

            在用數組作為數據結構存儲數據的時候,一不小心就訪問越界了,這類錯誤有時候很不容易發現。為此自己封裝一個專門用來訪問數組元素的指針類模板。此類模板需要數組的元素類型,起始地址,大小來構造一個安全的Ptr2T指針對象,此對象訪問數組的方法不但與普通的指針相同,同時還增加了越界的安全檢查。

            #include <iostream>
            #include 
            <stdexcept>

            using namespace std;

            template
            <typename T>
            class Ptr2T {
            public:
            //構造函數,形參為數組起始地址和大小
                Ptr2T(T *p, int size)
                    : m_p(p), m_array(p), m_size(size) { };

                Ptr2T
            & operator++();                //前綴++
                const Ptr2T operator++(int);        //后綴++

                Ptr2T
            & operator--();                //前綴--
                const Ptr2T operator--(int);        //后綴--

                Ptr2T
            & operator+=(int n);
                Ptr2T
            & operator -=(int n);
            //安全的數組元素訪問操作
                T& operator*() const;  
            private:
                T 
            *m_p;           //訪問數組的指針
                T *m_array;       //保存數組的起始地址
                int m_size;       //保存數組的大小
            };

            template
            <typename T>
            inline Ptr2T
            <T>& Ptr2T<T>::operator++()
            {
                m_p 
            += 1;
                
            return *this;
            }

            template
            <typename T>
            inline 
            const Ptr2T<T> Ptr2T<T>::operator++(int)
            {
                Ptr2T current 
            = *this;
                
            ++(*this);       //用重載的前綴++來實現
                
                
            return current;
            }

            template
            <typename T>
            inline Ptr2T
            <T>& Ptr2T<T>::operator--()
            {
                m_p 
            -= 1;
                
            return *this;
            }

            template
            <typename T>
            inline 
            const Ptr2T<T> Ptr2T<T>::operator--(int)
            {
                Ptr2T current 
            = *this;
                
            --(*this);       //用重載的前綴--來實現

                
            return current;
            }

            template
            <typename T>
            inline T
            & Ptr2T<T>::operator*() const
            {
                
            if (m_p < m_array || m_p > m_array + m_size - 1) {  //越界檢查
                    throw out_of_range("out of range");
                }

                
            return *m_p;
            }

            template
            <typename T>
            inline Ptr2T
            <T>& Ptr2T<T>::operator+=(int n)
            {
                m_p 
            += n;
                
            return *this;
            }

            template
            <typename T>
            inline Ptr2T
            <T>& Ptr2T<T>::operator-=(int n)
            {
                m_p 
            -= n;
                
            return *this;
            }

            template
            <typename T>
            Ptr2T
            <T> operator+(const Ptr2T<T> &p, const int n)
            {
                
            return Ptr2T<T>(p) += n;   //用重載的+=來實現
            }

            template
            <typename T>
            Ptr2T
            <T> operator+(const int n, const Ptr2T<T> &p)
            {
                
            return p + n;
            }

            template
            <typename T>
            Ptr2T
            <T> operator-(const Ptr2T<T> &p, const int n)
            {
                
            return Ptr2T<T>(p) -= n;  //用重載的-=來實現
            }

            //使用方法
            int main(void)
            {
                
            char a[5= {'a''b''c''d''e'};
                
            int b[5= {12345}; 

                Ptr2T
            <char> pc(a, 5);
                Ptr2T
            <int> pi(b, 5);

                cout 
            << *pc++ << endl;
                pi
            --;
                pi 
            += 2;
                cout 
            << *(pi - 1<< endl;

                
            *++pi = 100;
                cout 
            << *pi << endl;
                
                
            return 0;
            }

            posted on 2009-08-13 18:29 Marcky 閱讀(367) 評論(0)  編輯 收藏 引用 所屬分類: C/C++

            亚洲日本久久久午夜精品| 国产精品免费看久久久| 精品久久久久久久中文字幕| 国产精品美女久久久m| 四虎国产永久免费久久| 亚洲а∨天堂久久精品9966| 久久久久亚洲精品无码蜜桃| 久久精品国产99国产精品| 久久综合鬼色88久久精品综合自在自线噜噜 | 狠狠精品干练久久久无码中文字幕| 精品视频久久久久| 亚洲国产精品久久电影欧美| 国产精品久久久久一区二区三区| 久久婷婷五月综合成人D啪 | 久久久久国产日韩精品网站| 亚洲国产欧美国产综合久久| 18岁日韩内射颜射午夜久久成人| 少妇人妻88久久中文字幕| 狠狠色婷婷综合天天久久丁香 | 久久99热这里只有精品国产| 久久综合给合久久国产免费| 精品久久久久久无码国产| 91精品国产91久久久久福利| 精品久久久久久中文字幕大豆网| 国产精品亚洲美女久久久| 久久永久免费人妻精品下载| 亚洲中文字幕无码久久2017 | 香蕉99久久国产综合精品宅男自| 日产精品久久久久久久| 久久久久亚洲av综合波多野结衣| 久久中文字幕视频、最近更新| 九九久久自然熟的香蕉图片| 无码国内精品久久人妻| 久久无码AV中文出轨人妻| 久久久久免费视频| 韩国三级中文字幕hd久久精品 | 狠狠综合久久AV一区二区三区| 色偷偷88欧美精品久久久 | 88久久精品无码一区二区毛片 | 人妻精品久久久久中文字幕一冢本| 久久夜色撩人精品国产|