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

            西城

            指尖代碼,手上年華

            聯(lián)系 聚合 管理
              20 Posts :: 0 Stories :: 62 Comments :: 0 Trackbacks
            首先,命名空間為boost,array較小,只有一個單獨的array.hpp文件。
            array的目的主要是在STL的動態(tài)數(shù)組與傳統(tǒng)功能有限的普通數(shù)組之間做一個折衷。為高效的靜態(tài)數(shù)組增添一些其他的功能。

             

            template<class T,std::size_t N>
            class array{
            public:
            T elems[N];

             

            內(nèi)部的底層實現(xiàn)即用的傳統(tǒng)的數(shù)組。數(shù)組的大小由初始化時指定,但類型則由模板指定。

            public:
            // type definitions
            typedef T value_type;
            typedef T* iterator;
            typedef const T* const_iterator;
            typedef T& reference;
            typedef const T& const_reference;
            typedef std::size_t size_type;
            typedef std::ptrdiff_t difference_type;

            類似于STL的特性萃取機(jī)制。

            // iterator support
            iterator begin() { return elems; }
            const_iterator begin() const { return elems; }
            const_iterator cbegin() const { return elems; }

            iterator end() { return elems+N; }
            const_iterator end() const { return elems+N; }
            const_iterator cend() const { return elems+N; }


            提供類似于STL容器的接口。但這里的實現(xiàn)很簡單,因為是靜態(tài)數(shù)組。注意end()返回的指針是指向
            數(shù)組之后的一位,這點同STL的接口一致。

            reverse_iterator rbegin() { return reverse_iterator(end()); }
            const_reverse_iterator rbegin() const {
            return const_reverse_iterator(end());
            }
            const_reverse_iterator crbegin() const {
            return const_reverse_iterator(end());
            }

            reverse_iterator rend() { return reverse_iterator(begin()); }
            const_reverse_iterator rend() const {
            return const_reverse_iterator(begin());
            }
            const_reverse_iterator crend() const {
            return const_reverse_iterator(begin());
            }

            反向迭代器,也是類似于STL中的功能,在具體實現(xiàn)上就是用的STL的函數(shù)將普通迭代器轉(zhuǎn)化。

            // operator[]
            reference operator[](size_type i)
            {
            BOOST_ASSERT( i < N && "out of range" );
            return elems[i];
            }

            const_reference operator[](size_type i) const
            {
            BOOST_ASSERT( i < N && "out of range" );
            return elems[i];
            }

            重載【】操作符,兩個版本:const和非const.BOOST_ASSERT是BOOST庫提供的靜態(tài)斷言功能,可以在編譯期
            發(fā)現(xiàn)錯誤。比如說在程序編譯時就可以發(fā)現(xiàn)數(shù)組越界,報錯。C的最新標(biāo)準(zhǔn)里也加入了靜態(tài)斷言的內(nèi)容。

            // at() with range check
            reference at(size_type i) { rangecheck(i); return elems[i]; }
            const_reference at(size_type i) const { rangecheck(i); return elems[i]; }

            at()訪問函數(shù)。亦分const 與非const 版本,二者的不同體現(xiàn)雜返回值上。注意前面的定義,reference
            為T&,const_reference為const T&.實現(xiàn)上首先也是邊界檢查,我們來看一下rangecheck函數(shù)

            // check range (may be private because it is static)
            static void rangecheck (size_type i) {
            if (i >= size()) {
            std::out_of_range e("array<>: index out of range");
            boost::throw_exception(e);
            }
            }

            若游標(biāo)大于界限,則拋出異常,std::out_of_range,

            class out_of_range : public logic_error {
            public:
            explicit out_of_range (const string& what_arg);
            };


            class logic_error : public exception {
            public:
            explicit logic_error (const string& what_arg);
            };

            這里的異常的主要是為了向編譯者提供一個清晰的錯誤說明。

            // front() and back()
            reference front()
            {
            return elems[0];
            }

            const_reference front() const
            {
            return elems[0];
            }

            reference back()
            {
            return elems[N-1];
            }

            const_reference back() const
            {
            return elems[N-1];
            }

            front和back函數(shù),實現(xiàn)起來是很簡單的,也很高效的。

            // size is constant
            static size_type size() { return N; }
            static bool empty() { return false; }
            static size_type max_size() { return N; }
            enum { static_size = N };

            類似于STL容器的返回大小的接口。因為是靜態(tài)數(shù)組,大小不變,所以主要的目的只是為了與STL
            的接口兼容,實現(xiàn)起來并沒有多大意義。像empty()函數(shù),對vector來說很有用,但對一個長度固定的
            函數(shù)則是沒有什么意義的(總是返回false),所以在設(shè)計上主要的考慮是在別的地方。

            // swap (note: linear complexity)
            void swap (array<T,N>& y) {
            for (size_type i = 0; i < N; ++i)
            boost::swap(elems[i],y.elems[i]);
            }

            boost:swap是utility中的一個組件。其實現(xiàn)如下:

            namespace boost
            {
            template<class T1, class T2>
            void swap(T1& left, T2& right)
            {
            ::boost_swap_impl::swap_impl(left, right);
            }
            }

            而swap_impl的實現(xiàn)在boost命名空間之外。

            namespace boost_swap_impl
            {
            template<class T>
            void swap_impl(T& left, T& right)
            {
            using namespace std;//use std::swap if argument dependent lookup fails
            swap(left,right);
            }

            template<class T, std::size_t N>
            void swap_impl(T (& left)[N], T (& right)[N])
            {
            for (std::size_t i = 0; i < N; ++i)
            {
            ::boost_swap_impl::swap_impl(left[i], right[i]);
            }
            }
            }

            boost:swap有兩個template的好處是可以很好地與std:swap分別開來。當(dāng)同時出現(xiàn)時,std:swap是優(yōu)先的。

            // direct access to data (read-only)
            const T* data() const { return elems; }
            T* data() { return elems; }

            直接返回數(shù)組首地址。

            T* c_array() { return elems; }

            直接返回數(shù)組首地址用于進(jìn)行C類型的數(shù)組操作。

            template <typename T2>
            array<T,N>& operator= (const array<T2,N>& rhs) {
            std::copy(rhs.begin(),rhs.end(), begin());
            return *this;
            }

            賦值操作符。用的是STL中的通用算法。

            void assign (const T& value) { fill ( value ); } // A synonym for fill
            void fill (const T& value)
            {
            std::fill_n(begin(),size(),value);
            }

            posted on 2012-03-24 23:05 西城 閱讀(1509) 評論(1)  編輯 收藏 引用 所屬分類: Boost

            Feedback

            # re: Boost:array源碼解析 2012-03-25 09:49 tb
            很棒的   回復(fù)  更多評論
              

            久久妇女高潮几次MBA| 欧美大香线蕉线伊人久久| 久久99精品久久只有精品 | 国产色综合久久无码有码| 久久精品国产亚洲AV高清热| 日本久久久久久久久久| 中文字幕人妻色偷偷久久| 国内精品久久久久久野外| 亚洲欧美成人久久综合中文网| 久久精品中文騷妇女内射| 久久久久人妻精品一区三寸蜜桃| 久久久一本精品99久久精品66| 久久精品国产精品亚洲精品| 狠狠色丁香久久婷婷综合_中| 久久男人中文字幕资源站| 国产日韩久久免费影院| 狠狠干狠狠久久| 狠狠色婷婷久久一区二区| 久久久久免费视频| 热99re久久国超精品首页| 国产精品久久久久aaaa| 久久九九青青国产精品| 久久精品国产99久久久古代| 久久久久成人精品无码| 久久99精品国产99久久6男男| 一本久久a久久精品亚洲| 日产久久强奸免费的看| 国产精品内射久久久久欢欢| 99久久精品国产麻豆| 亚洲日韩中文无码久久| 久久精品国产AV一区二区三区| 色天使久久综合网天天| 久久夜色精品国产亚洲| 国产精品99久久久精品无码| 亚洲欧美日韩精品久久亚洲区 | 国内精品久久久久久不卡影院| 久久国产美女免费观看精品| 久久综合九色综合97_久久久| 国产91久久精品一区二区| 91久久精一区二区三区大全| 91视频国产91久久久|