• <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++
            久久久久国产一级毛片高清板 | 亚洲中文久久精品无码ww16| 伊人久久国产免费观看视频| 国内精品伊人久久久久777| 亚洲国产欧美国产综合久久| 久久狠狠色狠狠色综合| 国产精品成人久久久| 国产精品久久久久AV福利动漫| 精品久久久久久无码免费| 中文字幕亚洲综合久久菠萝蜜| 69久久夜色精品国产69| 久久综合伊人77777麻豆| 99精品久久精品一区二区| 久久久久久国产精品免费免费| 亚洲va中文字幕无码久久| 伊人久久大香线蕉影院95| 久久精品亚洲精品国产色婷| 欧美久久综合九色综合| 国产一区二区精品久久凹凸| 久久99精品国产自在现线小黄鸭| 久久综合给合综合久久| 久久综合九色综合97_久久久| 久久久这里有精品| 性做久久久久久久久老女人| 99久久免费国产精品| 久久91综合国产91久久精品| 久久99热只有频精品8| 久久久精品人妻一区二区三区蜜桃| 久久乐国产综合亚洲精品| 亚洲精品美女久久久久99小说| 亚洲午夜精品久久久久久人妖| 久久99国产亚洲高清观看首页| 国产V综合V亚洲欧美久久| 久久久av波多野一区二区| 99久久99久久精品免费看蜜桃| 国产亚洲综合久久系列| 99久久99这里只有免费费精品| 国产精品一久久香蕉国产线看观看 | 久久成人18免费网站| 久久精品亚洲男人的天堂| 国产巨作麻豆欧美亚洲综合久久 |