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

            常用鏈接

            留言簿

            隨筆分類

            隨筆檔案

            文章檔案

            牛人博客

            搜索

            積分與排名

            最新評論

            閱讀排行榜

            久久久久久无码国产精品中文字幕| 人妻无码精品久久亚瑟影视| 色综合久久88色综合天天 | 69久久夜色精品国产69| 久久久噜噜噜久久熟女AA片 | 伊人久久大香线蕉成人| 久久996热精品xxxx| 久久久久久av无码免费看大片| 精品熟女少妇aⅴ免费久久| 91亚洲国产成人久久精品| 国产福利电影一区二区三区,免费久久久久久久精 | 亚洲AV无码久久精品成人 | 久久乐国产精品亚洲综合| 久久激情五月丁香伊人| 亚洲&#228;v永久无码精品天堂久久 | 1000部精品久久久久久久久| 狠狠干狠狠久久| 久久久久久毛片免费看| 久久久久亚洲AV成人网人人网站| 国产精品久久久香蕉| 欧洲成人午夜精品无码区久久| 2022年国产精品久久久久| 99久久99久久精品国产| 欧美成a人片免费看久久| 欧美伊人久久大香线蕉综合| 日韩av无码久久精品免费| 久久亚洲欧美日本精品| 亚洲国产精品无码久久青草| 亚洲级αV无码毛片久久精品| 国产精品99久久免费观看| 91精品久久久久久无码| 国产99久久久国产精品小说| 久久国产色AV免费看| 午夜精品久久久久成人| 久久久久久亚洲Av无码精品专口| 久久天天躁狠狠躁夜夜不卡| 三上悠亚久久精品| 久久久久国产一级毛片高清板| 久久精品亚洲中文字幕无码麻豆 | 国产亚洲美女精品久久久久狼| 久久国产精品免费一区|