• <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 閱讀(3657) 評論(8)  編輯 收藏 引用 所屬分類: C++
            GCC編譯器似乎不能理解繼承自模板類里的數據成員。我還以為是代碼的問題,郁悶了半天后,居然在Borland C++ 5.5下編譯通過了。節(jié)省篇幅,我抽出主要部分。
            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 死循環(huán)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
            大部分編譯器的實現(xiàn)都是在初始化列表里滿足此項要求,而構造函數體這一要求都放寬了,跟人覺得這一要求也確實沒有什么道理,因為在調用子類構造函數的時候基類都已經構造完畢了。標準也只是標準而已。

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

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

            # 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++的這個特性讓我很不爽。
            久久精品国产亚洲AV影院| 久久婷婷国产综合精品 | 亚洲人成无码www久久久| 久久露脸国产精品| 无码国内精品久久人妻蜜桃| 久久se精品一区精品二区| 久久久人妻精品无码一区| 性欧美大战久久久久久久久 | 国产精品久久久久影院嫩草| 国产女人aaa级久久久级| 亚洲va国产va天堂va久久| 国产—久久香蕉国产线看观看| 狠狠精品久久久无码中文字幕| 青草影院天堂男人久久| 亚洲乱码中文字幕久久孕妇黑人| 亚洲天堂久久精品| 久久99国内精品自在现线| 亚洲性久久久影院| 99热都是精品久久久久久| 欧美午夜精品久久久久免费视| 久久久91人妻无码精品蜜桃HD| 99久久超碰中文字幕伊人| 久久久久se色偷偷亚洲精品av| 久久精品无码av| AAA级久久久精品无码区| 99国产欧美久久久精品蜜芽| 久久久久久精品免费免费自慰| 日韩美女18网站久久精品| 国产99久久久国产精免费| 2022年国产精品久久久久 | 狠狠色丁香久久婷婷综| 亚洲综合伊人久久大杳蕉| 久久亚洲AV无码精品色午夜| 久久精品亚洲欧美日韩久久 | 久久精品人成免费| 久久久久亚洲精品天堂| 亚洲精品午夜国产VA久久成人 | 国产人久久人人人人爽| 三上悠亚久久精品| 91视频国产91久久久| 久久精品国产99国产电影网 |