• <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 - 5, comments - 40, trackbacks - 0, articles - 0

            GCC不能正確繼承模板類?

            Posted on 2008-03-02 07:10 Wang Jinbo 閱讀(3684) 評論(8)  編輯 收藏 引用 所屬分類: C++
            GCC編譯器似乎不能理解繼承自模板類里的數據成員。我還以為是代碼的問題,郁悶了半天后,居然在Borland C++ 5.5下編譯通過了。節省篇幅,我抽出主要部分。
            template<class T>  
            class A{  
                
            protected:  
                    T id;  
            };  
            template
            <class T>  
            class B: public A<T>{  
                
            public:  
                    
            void setid(T i){  
                        id
            =i;  
                    }  
                    
            void test1(){  
                        cout
            <<"B::test1() ID: "<<id<<endl;  
                    }  
            };
            B類的id本應該是從A類里繼承來的,但用GCC編譯會提示說變量id未定義。試著用Borland的編譯器就很痛快地過了。我使用的是MinGW的 GCC 3.4,但我在Unix-Center的機器上使用Unix和Linux版本的GCC 4.0編譯仍然通不過,但Solaris上的Sun Studio的C++編譯器則沒問題。
            難道就這么幸運地碰上GCC的Bug了?

            Feedback

            # re: GCC不能正確繼承模板類?  回復  更多評論   

            2008-03-02 09:22 by Santa
            你要是用到父類變量需要加 this->
            或者在子類聲明的時候標明 using A;

            # re: GCC不能正確繼承模板類?  回復  更多評論   

            2008-03-02 09:39 by 死循環ing...
            template<class T>
            class A{
            protected:
            T id;
            };
            template<class T>
            class B: public A<T>{
            public:
            void setid(T i){
            A<T>::id=i;
            }
            void test1(){
            cout<<"B::test1() ID: "<<A<T>::id<<endl;
            }
            };
            根據錯誤提示,說明未指定域,所以修改了一下,就通過了,原因不明(= =")
            GCC4.2.1-sjlj

            # re: GCC不能正確繼承模板類?  回復  更多評論   

            2008-03-02 11:33 by 空明流轉
            這似乎是gcc編譯器本身的問題。

            # re: GCC不能正確繼承模板類?  回復  更多評論   

            2008-03-02 12:06 by stO
            G++做的是對的,你應該回去好好看看C++標準.
            同時你可以用-fpermissive放寬要求

            # re: GCC不能正確繼承模板類?  回復  更多評論   

            2008-03-02 15:56 by 空明流轉
            @stO
            大部分編譯器的實現都是在初始化列表里滿足此項要求,而構造函數體這一要求都放寬了,跟人覺得這一要求也確實沒有什么道理,因為在調用子類構造函數的時候基類都已經構造完畢了。標準也只是標準而已。

            # re: GCC不能正確繼承模板類?  回復  更多評論   

            2008-03-03 13:48 by eXile
            這個設計到模板的兩次掃描機制,VC或BC的做法可以使編譯略微快一些,但是會對一些還沒有實例化的模板代碼中的語法錯誤視而不見,而GCC的做法更為穩妥一些,也是符合標準的的行為。

            # re: GCC不能正確繼承模板類?  回復  更多評論   

            2008-03-05 10:49 by zhiyong
            “對一些還沒有實例化的模板代碼中的語法錯誤視而不見”
            是完全符合 C++ 標準的,而且這種特性還是有用的

            # re: GCC不能正確繼承模板類?  回復  更多評論   

            2008-07-14 10:56 by ytj
            經測試,用using a;A<T>::id;this->都可以解決問題,不過G++的這個特性讓我很不爽。
            亚洲精品国精品久久99热一| 精品国产青草久久久久福利| 亚洲国产精品18久久久久久| 久久久久久久人妻无码中文字幕爆| 久久人妻少妇嫩草AV无码专区| 久久se精品一区二区| 久久亚洲高清综合| 996久久国产精品线观看| 久久久精品久久久久特色影视| 99久久精品国产一区二区| 国产伊人久久| 精品免费tv久久久久久久| 精品人妻伦九区久久AAA片69| 99久久亚洲综合精品成人| 婷婷久久久亚洲欧洲日产国码AV| 久久伊人中文无码| 精品久久久久久| 99久久人妻无码精品系列| 久久精品国产AV一区二区三区 | 久久婷婷人人澡人人爽人人爱| 久久国产精品99精品国产987| 久久国内免费视频| 久久国产精品99久久久久久老狼 | 国产精品午夜久久| 久久亚洲国产欧洲精品一 | 国产女人aaa级久久久级| 久久久久亚洲Av无码专| 久久久国产精华液| 精品久久人人爽天天玩人人妻| 色99久久久久高潮综合影院| 久久婷婷五月综合成人D啪| 国产高潮久久免费观看| 久久综合欧美成人| 久久精品国产亚洲精品| 国产精品久久久久久久久久免费| 一本久久久久久久| 久久成人18免费网站| 区亚洲欧美一级久久精品亚洲精品成人网久久久久 | 久久久久久久久波多野高潮| 久久亚洲AV成人无码软件| 婷婷久久久亚洲欧洲日产国码AV|