• <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>
            Lyt
            posts - 16,comments - 61,trackbacks - 0
            最近由于需要頻繁使用Dictionary,于是就動手實現了一個,希望和List可以隨意地換來換去。
            //IList.h
            template<typename _Type>
            class IIList : public ICollection<_Type>{};

            //List.h
            template<typename _Type>
            class List : public IList<_Type>{};

            //IDictionary.h
            template<typename TKey, typename TValue>
            class IDictionary : public ICollection<Pair<TKey, TValue>>{};
            我希望IDictionary.h提供一個ToList() GetKeys() GetValues() 的操作,如果返回IList:

            error C2682: cannot use 'dynamic_cast' to convert from 'const Lyt::Collection::List<_Type> *' to 'Lyt::Collection::IList<_Type> *' e:\c++\library\library\library\collection\dictionary.h 171

            為啥會有編譯錯誤,至今不明,明明List繼承了IList怎么還會轉換失敗=  =

            還有另外一個問題,在實現GetKeys()時,我希望是返回IList而非List,這樣如果我以后有其他關于List的實現就不需要修改代碼了,考慮到內存泄漏的問題,我只想到兩種解決方法,不知道到底怎么折騰才合適,求解答。

            //方法一
            #include "List.h"
            template
            <typename TKey, typename TValue>
            class Dictionary : public IDictionary<TKey, TValue>
            {
            protected:
              List
            <Pair<TKey, TValue>> Data;
            public:
              AutoPtr
            <IList<Pair<TKey, TValue>>> GetKeys()const
              {
                AutoPtr
            <IList<Pair<TKey, TValue>>> Result=new List<TKey>//用引用計數實現的智能指針
                /**/
              }
            };

            //方法二
            #include "List.h"
            template
            <typename TKey, typename TValue>
            class Dictionary : public IDictionary<TKey, TValue>
            {
            protected:
              List
            <Pair<TKey, TValue>> Data;
              List
            <TKey> Keys; //本來我只需要一個List來存放東西就夠了,這樣我在其他的Add、Remove等操作中都要多折騰一個Keys,是不是沒有必要?
            public:
              
            const IList<TKey>* GetKeys()const
              {
                
            return dynamic_cast<IList<TKey>*>(&Keys);
              }
            };
            posted on 2009-10-15 09:44 Lyt 閱讀(1452) 評論(5)  編輯 收藏 引用 所屬分類: 數據結構

            FeedBack:
            # re: Dictionary的囧狀
            2009-10-15 13:43 | OwnWaterloo
            1.
            error C2682: cannot use 'dynamic_cast' to convert from 'const Lyt::Collection::List<_Type> *' to 'Lyt::Collection::IList<_Type>
             
            明白了嗎?
             
            2.
            IDictionary.h  include  List.h
            Dictionary.h include IDictionary.h
            相互包含在哪?
             
             
             
            C++不是這么用的……  被C#熏昏頭的同學……
              回復  更多評論
              
            # re: Dictionary的囧狀
            2009-10-15 15:39 | Lyt
            @OwnWaterloo
            沒有相互包含的狀況,抱歉…
            已經解決const的問題了,謝。

            數據結構的確是模仿.NET的,呃,不太明白為什么你說C++不是這么用的?  回復  更多評論
              
            # re: Dictionary的囧狀
            2009-10-15 22:30 | OwnWaterloo
            @Lyt
            你也發現問題了不是? 內存不好管理。

            如果你用GP的思想去實現Dictionary, GetKeys可以很簡單,并且很高效的實現。
            用OOP? 就等著承受虛函數開銷以及內存管理的困擾吧。。。
            然后,你又會為此去寫智能指針, 寫內存池, 寫鎖 ……

            你可以把這些當作練習…… 但這不是C++的style ……  回復  更多評論
              
            # re: Dictionary的囧狀
            2009-10-15 22:52 | OwnWaterloo
            我說具體一點吧……
            如果用GP(代碼一切從簡):
             
            template<typename T>
            class /*array*/list {
                T *first,*last_;
            public:
                typedef T* iterator;
                typedef const T* const_iterator;
             
                iterator begin() { return first_; }
                iterator end() { return last_; }
                const_iterator begin() const { return first_; }
                const_iterator end() const { return last_; } 
                // ...
            };
             
            要迭代一個容器:
            list<int> l;
            for ( list<int>::iterator first = l.begin(), last = l.end(), first!=last; ++first)
                visit_element( *first );
             
            而你遇到的問題就是:
            list<pair<key,value> > d;
            如何得到一個迭代器, 僅僅訪問key部分, 而不訪問value部分。
             
            template<class It>
            class project_first {
                It it_;
            public:
                project_first( It it ) : it_(it) {}
                typename std::iterator_traits<It>::value_type::first_type&
                    operator*() const { return it->first; }
                // 再實現 ++, -- +n 等操作...
            };
             
            for ( project_first first = d.begin(), last = d.end(); first!=last; ++first)
                visit_key( *first );
             
             
            如果d是 list<tuple<key,value> > 類型, project_iterator還可以做得更范化一些。
             
            沒有虛函數調用,沒有動態內存分配。
            并且,和stl的算法,boost的算法,以及其他C++組件合作良好。
              回復  更多評論
              
            # re: Dictionary的囧狀
            2009-10-15 23:14 | OwnWaterloo
            C#的template能做什么我不太清楚。

            C++支持編譯時的ducking type機制。
            拋棄這種強大的抽象機制不用, 轉而在C++這種暫不提供GC的語言中使用接口來作為數據結構之間的紐帶 ……
            所以…… 我說這不是C++的style ……

            還有一些小地方。 比如main 的返回類型是int, 而不是C#中的void。
            以單下劃線接大寫字母開頭,以及以雙下劃線開頭的標識符在C++中是被保留的。
            最好不要將C#中的那些習慣帶到C++中來……
            用Type, Type_, 別用_Type。

            這些被保留的標識符不會被永遠保留。 _Bool, _LongLong, _Complex已經出現。



            http://www.shnenglu.com/Streamlet/
            這位同學, 和你在做類似的事情, 也遇到了類似的問題。
            你可以參考參考……  回復  更多評論
              
            亚洲国产一成人久久精品| 99热成人精品免费久久| 久久精品一本到99热免费| 99久久国产宗和精品1上映| 久久国产热精品波多野结衣AV| 久久99精品久久久久久hb无码| 大蕉久久伊人中文字幕| 内射无码专区久久亚洲| 欧美大香线蕉线伊人久久| 国产精品九九久久精品女同亚洲欧美日韩综合区 | 日韩精品久久久肉伦网站| 99国产欧美久久久精品蜜芽| 久久久国产一区二区三区| 性高湖久久久久久久久| 久久精品亚洲乱码伦伦中文| 777米奇久久最新地址| 人妻无码精品久久亚瑟影视| 国产福利电影一区二区三区,免费久久久久久久精 | 久久国产福利免费| 久久66热人妻偷产精品9| 国产69精品久久久久观看软件 | 18岁日韩内射颜射午夜久久成人| 色综合久久精品中文字幕首页 | 久久97久久97精品免视看| 国产精品对白刺激久久久| 亚洲日本va中文字幕久久| 要久久爱在线免费观看| 久久久久国产| 色综合久久88色综合天天 | 久久国产视屏| 久久亚洲欧洲国产综合| 久久精品国产亚洲av瑜伽| 亚洲国产精品久久久久婷婷软件 | 亚洲精品tv久久久久久久久| 久久这里都是精品| 久久久久久久91精品免费观看| 欧美久久久久久精选9999| 99热热久久这里只有精品68| 青青青青久久精品国产 | 国产成人精品综合久久久| 久久久国产打桩机|