• <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 閱讀(3667) 評論(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++的這個特性讓我很不爽。
            91亚洲国产成人久久精品| 久久久久亚洲AV综合波多野结衣| 久久精品亚洲精品国产欧美| 久久中文字幕精品| 国产三级久久久精品麻豆三级| 精品精品国产自在久久高清 | 久久狠狠爱亚洲综合影院| 人妻少妇久久中文字幕一区二区 | 99久久精品免费看国产免费| 亚洲国产成人精品91久久久| 久久精品国产久精国产思思| 久久久久国产一区二区三区| 2021少妇久久久久久久久久| 色老头网站久久网| 九九久久精品国产| 国产精品一久久香蕉国产线看观看| 久久精品成人免费国产片小草| 久久丫精品国产亚洲av| 亚洲国产成人精品女人久久久| 久久99中文字幕久久| 久久天天躁夜夜躁狠狠| 久久综合久久鬼色| 91久久精品国产免费直播| 久久亚洲精品中文字幕| 久久精品日日躁夜夜躁欧美| 日韩影院久久| 久久久久久国产精品免费免费 | 亚洲国产精品一区二区久久hs| 久久午夜综合久久| 久久99热这里只有精品国产| 亚洲国产精品久久久久久| 久久精品九九亚洲精品天堂| 久久久久亚洲精品无码蜜桃| 日产精品久久久久久久| 亚洲午夜久久久久久久久电影网| 国产99久久久国产精品小说| 亚洲精品国精品久久99热| 久久天天躁狠狠躁夜夜不卡| 国色天香久久久久久久小说| 一本色道久久88精品综合| 亚洲伊人久久精品影院|