• <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++之父力作學(xué)習(xí)筆記(4)——類的好多事

                  類,這個概念比較大。包含的事太多。咱們就一一的盡量弄清楚它。
                  一個類就是一個用戶定義類型。C++里類概念的目標(biāo)就是為程序員提供一種建立新類型的工具,是這些新類型的使用能夠像內(nèi)部一樣方便。
                  訪問控制:class成員的默認(rèn)訪問方式是私有的。一個struct也是一個class,但是其成員的默認(rèn)方式是公用的。非成員函數(shù)禁止訪問私有成員。
                  構(gòu)造函數(shù):就是函數(shù)名和類名一樣的函數(shù)且沒有返回值。這誰都知道。It's easy。而默認(rèn)構(gòu)造函數(shù)就是調(diào)用時不必提供參數(shù)的構(gòu)造函數(shù)。如果用戶自己聲明了一個默認(rèn)構(gòu)造函數(shù),那么就會去使用它;否則,如果有必要,而且用戶沒有聲明其他的構(gòu)造函數(shù),編譯器就會設(shè)法去生成一個。編譯器生成的默認(rèn)構(gòu)造函數(shù)將隱式地為類類型的成員和它的基類調(diào)用有關(guān)的默認(rèn)構(gòu)造函數(shù)。這里解釋一下:類類型(Class type)即指那些由程序員定義的類而產(chǎn)生的類型,以便與內(nèi)部類型和其他用戶定義類型相區(qū)分。相信大家這里也沒什么問題。有一個注意點來了,由于const和引用必須進行初始化,包含const或引用成員的類就不能進行默認(rèn)構(gòu)造,除非程序員的我們自己顯示的提供默認(rèn)構(gòu)造函數(shù)。例如:
            struct X
            {
                
            const int a;
                
            const int& r;
            }
            ;
            X x;
            //錯誤;X無默認(rèn)構(gòu)造函數(shù)
                  默認(rèn)構(gòu)造函數(shù)也可以顯示調(diào)用。內(nèi)部類型同樣也有默認(rèn)構(gòu)造函數(shù)。
                  下面再談?wù)剰?fù)制構(gòu)造函數(shù),先看看復(fù)制構(gòu)造函數(shù)是怎么引進來的。
            按照默認(rèn)約定,類對象可以復(fù)制。特別是可以用一個類的對象和復(fù)制對該類的其他對象進行初始化。即使是聲明了構(gòu)造函數(shù)的地方,也是可以這樣做:
            Date d=today;//通過復(fù)制初始化
            按照默認(rèn)方式,類對象的復(fù)制就是其中各個成員的復(fù)制。如果某個類X所需要的不是這種默認(rèn)方式,那么就可以定義一個復(fù)制構(gòu)造函數(shù)X::X(const X&),由它提供所需要的行為。還有一個概念就是復(fù)制賦值,很容易和復(fù)制構(gòu)造函數(shù)搞混。咱們就一起搞清楚它們。先看一段程序:
            void h()
            {
                Table t1;
                Table t2
            =t1;//復(fù)制初始化
                Table t3;
                t3
            =t2;      //復(fù)制賦值
            }
            看似好像沒什么問題,對于復(fù)制上面提到的解釋方式,在應(yīng)用到具有指針成員的類的對象時,就可能產(chǎn)生一種出人意料的作用。對于包含了由構(gòu)造函數(shù)/析構(gòu)函數(shù)管理的資源的對象而言,按成員復(fù)制的語義通常是不正確的。在這里,Table的默認(rèn)構(gòu)造函數(shù)為t1和t3各調(diào)用了一次,一共是兩次。然而Table的析構(gòu)函數(shù)則被調(diào)用了三次;對t1、t2和t3各一次!由于賦值的默認(rèn)解釋是按成員賦值,所以在h()結(jié)束時,t1、t2和t3中將各包含一個指針,它們都指向建立t1時從自由存儲中分配的那個名字?jǐn)?shù)組。在建立t3時所分配的數(shù)組的指針并沒有保留下來,因為它被賦值t3=t2覆蓋掉了。這樣,如果沒有自動廢料收集,對這個程序而言,該數(shù)組的存儲就將永遠丟掉了。而在另一方面,為t1的創(chuàng)建而分配的數(shù)組因為同時出現(xiàn)在t1、t2和t3里,將被刪除3次。這種情況所導(dǎo)致的結(jié)果是無定義,很可能是災(zāi)難性的。這類反常情況可以避免,方式就是將Table復(fù)制的意義定義清楚:
            class Table
            {
                
            //---
                Table(const Table&);//復(fù)制構(gòu)造函數(shù)
                Table& operator=(const Table&);//復(fù)制賦值
            }
            ;
            咱們自己可以為這些復(fù)制操作定義自己認(rèn)為最合適的任何意義,例如
            //這里補上Table類的詳細定義
            class Table
            {
                Name
            * p;
                size_t sz;
            public:
                Table(size_t s
            =15)
                
            {
                    p
            =new Name[sz=s];
                }

                
            ~Table()
                

                    delete[] p;
                }

                Name
            * loopup(const char*);
                
            bool insert(Name*);
            }


            Table::Table(
            const Table& t)//復(fù)制構(gòu)造函數(shù)
            {
               p
            =new Name[z=t.sz];
               
            for(int i=0;i<sz;i++)
                  p[i]
            =t.p[i];
            }


            Table
            & Table::operator=(const Table& t)//賦值
            {
                
            if(this!=&t)//當(dāng)心自賦值:t=t
                
            {
                    delete[] p;
                    p
            =new Name[sz=t.sz];
                    
            for(int i=0;i<sz;i++)
                        p[i]
            =t.p[i];
                }

                
            return *this;
            }
            情況幾乎總是如此,復(fù)制構(gòu)造函數(shù)與復(fù)制賦值通常都很不一樣。究其根本原因,復(fù)制構(gòu)造函數(shù)是去完成對為初始化的存儲區(qū)的初始化,而復(fù)制賦值運算符則必須正確處理一個結(jié)構(gòu)良好的對象。
                  成員常量:
                  對那些靜態(tài)整型成員,可以給它的成員聲明加上一個常量表達式作為初始式,例如
            class Curious
            {
                
            static const int c1=7;//ok,但要記得去定義
                static int c2=11;//錯誤:非const
                const int c3;//錯誤:非Static
                static const int c4=f(1);//錯誤:在類里的初始表達式不是常量
                static const float c5=7.0;//錯誤:在類里初始化的不是整型
            }
            1)在類中不能用const來創(chuàng)建常量!因為:類只是描述了對象的形式,并沒有真正創(chuàng)建對象!所以, 在對象建立之前,并沒有存值空間!
            2)而const是用來創(chuàng)建常量的!
            方法1 你可以用枚舉:
            class a
            {
            enum{buf_size_t buf_size=、、、}//用枚舉創(chuàng)建一個常量,但不是數(shù)據(jù)成員

            }

            方法2 你可以用static
            class a
            {
            private
              
            static const buf_size_t buf_size=30//該常量將與憋得靜態(tài)常量存儲在一起,而不是存儲在對象中
            }
            但《C++程序設(shè)計語言》書上說當(dāng)你用到某個被初始化的成員,而且需要將它作為對象存入存儲器時,這個成員就必須在某處有定義。初始式不必重復(fù)寫:
            const int Curious::c1;//必須,但這里不必重復(fù)初始式
            const int* p=&Cusious::c1;//ok:Curious::c1已經(jīng)有定義
            這里有點讓我懵了,為什么還要const int Curious::c1;//必須,但這里不必重復(fù)初始式 這一行呢?還說是必須,經(jīng)過測試是有問題的——當(dāng)前范圍內(nèi)的定義或重新聲明非法,到底是書錯了還是還有其他什么原因?
            還請高手不吝賜教
            今天就到這里吧,到這里就出了問題,還需要思考。

            這里有一篇博文關(guān)于
            VC6.0中,整型const static成員不能在類的定義體中初始化. http://blog.csdn.net/yiruirui0507/article/details/5984530




            posted on 2011-08-05 17:00 Daywei 閱讀(2214) 評論(0)  編輯 收藏 引用 所屬分類: C++之父力作學(xué)習(xí)筆記

            <2016年9月>
            28293031123
            45678910
            11121314151617
            18192021222324
            2526272829301
            2345678

            導(dǎo)航

            統(tǒng)計

            常用鏈接

            留言簿

            隨筆分類

            隨筆檔案

            文章檔案

            牛人博客

            搜索

            積分與排名

            最新評論

            閱讀排行榜

            91精品国产高清久久久久久io | 色综合久久中文字幕无码| 精品国产青草久久久久福利| 久久这里只有精品首页| 99久久婷婷国产一区二区| 色欲综合久久躁天天躁| 亚洲精品乱码久久久久久蜜桃不卡| www.久久热| 久久久久久免费视频| 狠狠色丁香婷婷久久综合不卡| 很黄很污的网站久久mimi色| 欧美日韩精品久久免费| 亚洲国产成人久久综合碰碰动漫3d| 久久人人超碰精品CAOPOREN| 久久天天躁狠狠躁夜夜avapp| 狠狠久久亚洲欧美专区| 亚洲色欲久久久综合网| 99久久精品这里只有精品| 天堂久久天堂AV色综合| 久久久青草青青国产亚洲免观| 久久精品毛片免费观看| 久久综合九色综合欧美就去吻| 亚洲国产精品一区二区久久hs| 久久无码国产| 成人精品一区二区久久| av无码久久久久久不卡网站| 亚洲色婷婷综合久久| 欧洲国产伦久久久久久久| 亚洲国产精品久久久久婷婷软件 | 久久久久综合国产欧美一区二区| 午夜人妻久久久久久久久| 一本久道久久综合狠狠躁AV| 99久久精品这里只有精品| 久久精品国产免费| 国产精品视频久久久| 久久w5ww成w人免费| 无码超乳爆乳中文字幕久久| 成人午夜精品无码区久久| 亚洲中文字幕无码久久综合网| 久久www免费人成看片| 国产成人无码精品久久久性色|