• <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>
            posts - 7,  comments - 64,  trackbacks - 0

            最近在百度知道上回答了一道問(wèn)題,并為他封裝了一個(gè)類來(lái)解決。大意是不開(kāi)辟新的數(shù)組同時(shí)排序兩個(gè)數(shù)組。
            http://zhidao.baidu.com/question/112777967.html

            之后想要給這個(gè)類添加iterator好直接使用sort之類的函數(shù),經(jīng)過(guò)1個(gè)多小時(shí)的忙碌(能力有限,可以鄙視一下),終于實(shí)現(xiàn)了random_access_iterator。
            上源碼:

            template<typename T>
            class Obj;

            template<typename T>
            class Obj_iterator : public std::iterator <std::random_access_iterator_tag , T>
            {
            public:
                    Obj_iterator() : m_Obj(NULL) , m_index(0) {}
                    Obj_iterator( Obj<T> *p , size_t index ) : m_Obj(p) , m_index(index){}
                    Obj_iterator& operator = ( const  Obj_iterator &t )
                    {
                            m_index = t.m_index;
                            m_Obj = t.m_Obj;
                            return *this;
                    }
                    bool operator ==( const Obj_iterator &rh ) const
                    {
                            return rh.m_Obj == m_Obj && rh.m_index == m_index;
                    }
                    bool operator !=( const Obj_iterator &rh ) const
                    {
                            return !( *this == rh );
                    }
                    Obj_iterator operator ++()
                    {
                            ++m_index;
                            return Obj_iterator(m_Obj,m_index);
                    }
                    Obj_iterator operator ++( int )
                    {
                            Obj_iterator x = *this;
                            ++(*this);
                            return x;
                    }
                    Obj_iterator operator -- ()
                    {
                            --m_index;
                            return Obj_iterator(m_Obj , m_index);
                    }
                    //一開(kāi)始這里總是過(guò)不去,后來(lái)回想起以前遇到的問(wèn)題,才知道需要在后面加上const來(lái)修飾,原因如下
                    /*
                    C++不鼓勵(lì)把非常量引用綁定到臨時(shí)對(duì)象
                    非const的operator*有可能改變對(duì)象值,從而對(duì)象整體的const性質(zhì)得不到保證
                    */
                    T& operator *() const
                    {
                            return (*m_Obj)[m_index];
                    }
                    T* operator ->() const
                    {
                            return &(*m_Obj[m_index]);
                    }
                    const Obj_iterator operator +(size_t n)
                    {
                            return Obj_iterator(m_Obj , m_index + n);
                    }
                    const Obj_iterator operator += (size_t n)
                    {
                            m_index += n;
                            return *this;
                    }
                    difference_type operator -(const Obj_iterator &n)
                    {
                            return m_index - n.m_index;
                    }
                    Obj_iterator operator -(size_t n)
                    {
                            return Obj_iterator(m_Obj , m_index-n);
                    }
                    bool  operator < (const Obj_iterator n) const
                    {
                            return m_index<n.m_index;
                    }
            protected:
            private:
                    Obj<T> *m_Obj;
                    size_t m_index;
            };


            template <typename T>
            class Obj
            {
            public:
                    Obj(T *p1,size_t sizeofp1,T *p2,size_t sizeofp2):
                          m_p1(p1),
                          m_p2(p2),
                          m_sizeofp1(sizeofp1),
                          m_sizeofp2(sizeofp2)
                  {
                          m_sumsize = sizeofp1+sizeofp2;
                  }

             

                  typedef Obj_iterator<T>  iterator;

             

                  T& operator [](size_t index)
                  {
                          if (index > m_sizeofp1 + m_sizeofp2)
                          {
                                  throw std::out_of_range("out_of_range");
                          }
                          if (index<m_sizeofp1)
                          {
                                  return m_p1[index];
                          }
                          else
                          {
                                  return m_p2[index - m_sizeofp1];
                          }
                  }
                  size_t size() const
                  {
                          return m_sumsize;
                  }
                  iterator begin()
                  {
                          return iterator(this,0);
                  }
                  iterator end()
                  {
                          return iterator(this,m_sumsize);
                  }
            protected:
            private:
                    T *m_p1;
                    T *m_p2;
                    size_t m_sizeofp1;
                    size_t m_sizeofp2;
                    size_t m_sumsize;
            };

            int _tmain(int argc, _TCHAR* argv[])
            {
                    int p1[] = {1,6,3,123456,2,67,2,8};
                    int p2[] = {4,2,6,234,9,4,0,5};
                    Obj<int> h(p1 , sizeof(p1)/sizeof(*p1) , p2 , sizeof(p2)/sizeof(*p2));
                    std::copy(h.begin() , h.end() , std::ostream_iterator<int>(std::cout," "));
                    std::cout<<std::endl;
                    std::sort(h.begin() , h.end());
                    std::copy(h.begin() , h.end(),std::ostream_iterator<int>(std::cout,"\n"));
                    return EXIT_SUCCESS;
            }

             


            這段程序在我的vs2008上正確編譯執(zhí)行。

            posted on 2009-08-20 10:06 HIT@ME 閱讀(1904) 評(píng)論(4)  編輯 收藏 引用

            FeedBack:
            # re: 成功在自己的類中加入random_access_iterator,但也遇到新的問(wèn)題。
            2009-08-20 12:28 | OwnWaterloo
            template<typename T>
            class Obj;

            template<typename T>
            class Obj_iteator { ... };

            template<typename T>
            class Obj { ... };

            這樣嗎?  回復(fù)  更多評(píng)論
              
            # re: 成功在自己的類中加入random_access_iterator,但也遇到新的問(wèn)題。[未登錄](méi)
            2009-08-20 13:50 | HIT@ME
            @OwnWaterloo
            哎,我大腦進(jìn)水了。在類中聲明obj_iterator的時(shí)候居然忘記加類型說(shuō)明了。現(xiàn)在編譯通過(guò)了。謝謝啊~!  回復(fù)  更多評(píng)論
              
            # re: 成功在自己的類中加入random_access_iterator。
            2009-08-20 16:56 |
            好東西  回復(fù)  更多評(píng)論
              
            # re: 成功在自己的類中加入random_access_iterator。
            2009-08-21 17:20 | 樂(lè)蜂網(wǎng)
            不錯(cuò)啊  回復(fù)  更多評(píng)論
              

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


            <2009年8月>
            2627282930311
            2345678
            9101112131415
            16171819202122
            23242526272829
            303112345

            常用鏈接

            留言簿(5)

            隨筆檔案

            test

            搜索

            •  

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            久久亚洲国产成人影院网站| 亚洲色欲久久久综合网东京热| 国产成人无码精品久久久性色| 综合久久一区二区三区| 久久久国产99久久国产一| 久久人人爽人人爽人人av东京热| 久久精品国产色蜜蜜麻豆| 久久人人爽人人爽人人AV东京热 | 久久精品中文字幕一区| 伊人久久大香线蕉av不卡 | 日本精品久久久久影院日本| 性欧美丰满熟妇XXXX性久久久 | 久久久久人妻一区精品| 色综合久久久久无码专区| 久久久久一本毛久久久| 一本色道久久综合狠狠躁| 久久久精品国产Sm最大网站| 久久国产亚洲高清观看| 无码人妻久久一区二区三区蜜桃| 久久不射电影网| 国产V亚洲V天堂无码久久久| 国产精品亚洲综合久久| 久久精品国产99久久香蕉| 久久天堂电影网| 久久久久99精品成人片直播| 一日本道伊人久久综合影| 久久e热在这里只有国产中文精品99 | av无码久久久久久不卡网站| 亚洲欧美一级久久精品| 久久伊人影视| 久久亚洲欧洲国产综合| 久久久精品视频免费观看| 一本大道加勒比久久综合| 久久精品亚洲日本波多野结衣| 亚洲欧美日韩久久精品第一区| 欧美色综合久久久久久| 日韩欧美亚洲综合久久影院Ds| 久久久WWW免费人成精品| 久久久久亚洲AV成人网| 亚洲七七久久精品中文国产| 一本一本久久a久久精品综合麻豆|