• <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/
            這位同學, 和你在做類似的事情, 也遇到了類似的問題。
            你可以參考參考……  回復  更多評論
              
            久久久久久亚洲精品不卡| 精品久久人妻av中文字幕| 久久精品国产99久久香蕉| 日本欧美国产精品第一页久久| 人妻无码久久精品| 久久精品国产亚洲AV麻豆网站| 国产精品视频久久| 亚洲色欲久久久久综合网| 人妻少妇久久中文字幕| 狠狠人妻久久久久久综合| 久久久久久国产a免费观看黄色大片 | 久久综合香蕉国产蜜臀AV| 亚洲一区二区三区日本久久九| 午夜精品久久久久久| 韩国三级大全久久网站| 久久99精品国产麻豆宅宅| 国内精品久久久久久久coent| 99精品国产综合久久久久五月天| 青草国产精品久久久久久| 美女久久久久久| 久久综合丁香激情久久| 久久棈精品久久久久久噜噜| 久久久久久久久久免免费精品| 久久99精品久久久久婷婷| 蜜桃麻豆WWW久久囤产精品| 午夜精品久久久内射近拍高清| 亚洲国产二区三区久久| 国产成人综合久久综合| 久久久精品人妻一区二区三区四| 2020久久精品亚洲热综合一本| 欧美一级久久久久久久大片| 久久久精品人妻无码专区不卡 | 国产精品美女久久久| 亚洲AV日韩精品久久久久久| 亚洲国产精品无码久久久久久曰| 国产AV影片久久久久久| 四虎国产精品免费久久5151| 精品国产乱码久久久久久郑州公司 | 色欲久久久天天天综合网| 97精品国产97久久久久久免费| 久久久久人妻一区二区三区|