• <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>

            專注于c++

              C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
              21 Posts :: 0 Stories :: 4 Comments :: 0 Trackbacks

            常用鏈接

            留言簿(15)

            我參與的團隊

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

             

             

            1、 如何使用無參構造函數初始化?

            aClass obj();   //error,不能加括號

            aClass obj;

            2、聲明為引用的數據成員和const數據成員必須采用成員初始化列表進行初始化。

            3、類與const

            const成員函數定義:在該函數中不改變調用他的對象的值。

            eg: void Func() const;

            const成員函數可重載,根據對象是否是const來決定調用。

            構造函數和析構函數不能聲明為const

            const數據成員 必須在構造函數初始化列表中被初始化。

            eg: class test

            {

            test(int i):data(i) {}

            ……

            private:

                const int data;

            }

            注:const對象的“常量性質”在從構造函數完成對象初始化 對象析構函數被調用結束這個過程之間一直保持。

             

            static成員函數不能聲明為constconst指示函數不能修改它操作的對象的內容,但static成員函數獨立于類的任何對象。

             

            不一致使用const

             

            void Func2(int a[])

            {

            ……

            }

            void Func1(const int a[])

            {

                 Func2(a); //Error,不能將const修改為非constFunc2參數也該聲明為const

            ……

            } void Func2()vo

             

            4、友元friend,原型在類定義內出現,但友元不是成員函數,privateprotected等與友元無關,因此可以放在類的任何地方。

            5、在派生類的構造函數的初始化列表中初始化成員、調用基類的構造函數,可以防止重復初始化。

            6、若一個類中含virtual函數,則該類的析構函數應該為virtual

             

            7、重載復數類的+運算符。

             

            Complex operator + (const Complex& x,const Complex& y)

            {

                   return (a,b);   //此語句調用下面的構造函數

            }

             

            Complex::Complex(const Complex& x,const Comolex& y)

                     :real(x.real+y.real),imag(x.img+y.img)

            {

            }

             

            7、臨時對象

            class X

            {……};

             

            X x1(100);   //只有它不會產生臨時對象,只有1個構造函數被調用

            X x2=X(100);

            X x3=100;

             

             

            8、多重繼承

            繼承關系如下圖

            Employee

            Employer

            Worker

            Manager

            Engineer

            產生二義性:如

             Engineer   eng;

             eng.Worker::Sex=0;

             eng.Manager::Sex=1;

            解決方法:使用虛基類

               class Worker:public virtual Employee

            {

            };

             

            class Manager:public virtual Employer

            {

            };

            類之間的關系如下圖所示:

            Employer

            Worker

            Manager

            Engineer

            不過這樣還是存在問題的,這是c++自身所決定的。

            posted on 2009-09-30 16:19 bellgrade 閱讀(362) 評論(0)  編輯 收藏 引用 所屬分類: C/C++
            国产精品gz久久久| 久久久青草青青亚洲国产免观| 伊人久久大香线蕉亚洲五月天| 久久久久亚洲精品男人的天堂| 久久精品国产影库免费看| 久久国产精品99精品国产| 99蜜桃臀久久久欧美精品网站| 伊人久久大香线蕉无码麻豆| 一本伊大人香蕉久久网手机| 伊人丁香狠狠色综合久久| 一级做a爱片久久毛片| 久久人人爽人人爽人人片AV麻豆| 久久99国产精品成人欧美| 久久人人爽人人澡人人高潮AV| 亚洲欧美一区二区三区久久| 国产成人精品综合久久久久| 久久99精品久久久久久hb无码| 色综合久久综合网观看| 91久久精品视频| 伊人色综合九久久天天蜜桃| 久久精品国产99久久香蕉| 久久精品国产精品国产精品污| 久久精品无码一区二区WWW| 日韩欧美亚洲综合久久| 精品人妻久久久久久888| 香蕉久久夜色精品国产小说| 亚洲精品tv久久久久| 久久国产免费观看精品3| 久久噜噜久久久精品66| 久久超乳爆乳中文字幕| 久久精品极品盛宴观看| 精品免费tv久久久久久久| 久久综合鬼色88久久精品综合自在自线噜噜 | 久久久久人妻一区精品色| 久久亚洲精品中文字幕三区| 一本色道久久88综合日韩精品 | 久久97精品久久久久久久不卡| 免费精品久久久久久中文字幕| 国产成人久久精品一区二区三区| 久久国产福利免费| 伊人久久免费视频|