• <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,于是就動手實(shí)現(xiàn)了一個,希望和List可以隨意地?fù)Q來換去。
            //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怎么還會轉(zhuǎn)換失敗=  =

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

            //方法一
            #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>//用引用計(jì)數(shù)實(shí)現(xiàn)的智能指針
                /**/
              }
            };

            //方法二
            #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 閱讀(1454) 評論(5)  編輯 收藏 引用 所屬分類: 數(shù)據(jù)結(jié)構(gòu)

            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#熏昏頭的同學(xué)……
              回復(fù)  更多評論
              
            # re: Dictionary的囧狀
            2009-10-15 15:39 | Lyt
            @OwnWaterloo
            沒有相互包含的狀況,抱歉…
            已經(jīng)解決const的問題了,謝。

            數(shù)據(jù)結(jié)構(gòu)的確是模仿.NET的,呃,不太明白為什么你說C++不是這么用的?  回復(fù)  更多評論
              
            # re: Dictionary的囧狀
            2009-10-15 22:30 | OwnWaterloo
            @Lyt
            你也發(fā)現(xiàn)問題了不是? 內(nèi)存不好管理。

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

            你可以把這些當(dāng)作練習(xí)…… 但這不是C++的style ……  回復(fù)  更多評論
              
            # re: Dictionary的囧狀
            2009-10-15 22:52 | OwnWaterloo
            我說具體一點(diǎn)吧……
            如果用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; }
                // 再實(shí)現(xiàn) ++, -- +n 等操作...
            };
             
            for ( project_first first = d.begin(), last = d.end(); first!=last; ++first)
                visit_key( *first );
             
             
            如果d是 list<tuple<key,value> > 類型, project_iterator還可以做得更范化一些。
             
            沒有虛函數(shù)調(diào)用,沒有動態(tài)內(nèi)存分配。
            并且,和stl的算法,boost的算法,以及其他C++組件合作良好。
              回復(fù)  更多評論
              
            # re: Dictionary的囧狀
            2009-10-15 23:14 | OwnWaterloo
            C#的template能做什么我不太清楚。

            C++支持編譯時的ducking type機(jī)制。
            拋棄這種強(qiáng)大的抽象機(jī)制不用, 轉(zhuǎn)而在C++這種暫不提供GC的語言中使用接口來作為數(shù)據(jù)結(jié)構(gòu)之間的紐帶 ……
            所以…… 我說這不是C++的style ……

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

            這些被保留的標(biāo)識符不會被永遠(yuǎn)保留。 _Bool, _LongLong, _Complex已經(jīng)出現(xiàn)。



            http://www.shnenglu.com/Streamlet/
            這位同學(xué), 和你在做類似的事情, 也遇到了類似的問題。
            你可以參考參考……  回復(fù)  更多評論
              
            狠狠色婷婷久久一区二区三区| 国产福利电影一区二区三区久久久久成人精品综合 | 久久精品免费网站网| 久久久久亚洲精品无码网址 | 国产成人久久精品一区二区三区 | 中文字幕亚洲综合久久2| 久久久久人妻一区精品果冻| 精品久久久久久中文字幕大豆网| 久久精品国产免费| 国内精品伊人久久久影院| 成人国内精品久久久久一区| 精品国产91久久久久久久a | 久久久综合香蕉尹人综合网| 久久精品国产亚洲AV大全| 午夜精品久久久久久久无码| 怡红院日本一道日本久久 | 久久婷婷国产麻豆91天堂| 国产精品日韩深夜福利久久| 亚洲国产精品无码久久SM | 国产精品99久久久久久宅男小说| 久久久精品国产sm调教网站 | 久久五月精品中文字幕| 久久婷婷五月综合97色| 久久综合久久综合亚洲| 精品免费久久久久国产一区| A狠狠久久蜜臀婷色中文网| 久久夜色精品国产亚洲| 日韩亚洲国产综合久久久| 精品一久久香蕉国产线看播放| 精品久久久噜噜噜久久久| 国产亚洲精久久久久久无码77777| 久久久免费观成人影院| 久久国产综合精品五月天| 国产2021久久精品| 精品久久久久久久久久久久久久久| 国产精品一区二区久久国产| 久久久久av无码免费网| 思思久久99热只有频精品66| 尹人香蕉久久99天天拍| 久久国产免费直播| 伊人久久综合精品无码AV专区|