類與對(duì)象及封裝性_第1頁
類與對(duì)象及封裝性_第2頁
類與對(duì)象及封裝性_第3頁
類與對(duì)象及封裝性_第4頁
類與對(duì)象及封裝性_第5頁
已閱讀5頁,還剩16頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

當(dāng)豬類統(tǒng)治了世界類與對(duì)象及封裝性1.類的抽象2.類的定義與對(duì)象生成3.構(gòu)造函數(shù)和析構(gòu)函數(shù)1.類的抽象在現(xiàn)實(shí)世界中,任何一個(gè)實(shí)體都可以看成是一個(gè)對(duì)象。

一個(gè)對(duì)象具有如下二個(gè)方面的要素:對(duì)象的屬性:是實(shí)體自身所具有的性質(zhì)。如一個(gè)具體的人,他有身高、體重等特征。對(duì)象的方法:是實(shí)體自身所擁有的操作。如一個(gè)具體的人,他可以走、說話等動(dòng)作。類:按照上述二個(gè)方面去進(jìn)行歸納與抽象定義后所產(chǎn)生的類型類是具體對(duì)象的一個(gè)抽象的定義張三、李四、王五是一個(gè)個(gè)具體的人“人”就是類的概念張三、李四、王五就是“人”類的對(duì)象

對(duì)象是按照類的抽象定義的框架產(chǎn)生的,也就是說,類是這一類的對(duì)象的生成模型。面向?qū)ο蟮某绦蛟O(shè)計(jì):

通過對(duì)象的使用去完成應(yīng)用程序的2.類的定義與對(duì)象生成成員數(shù)據(jù):類的屬性數(shù)據(jù);成員函數(shù):對(duì)類的屬性數(shù)據(jù)進(jìn)行操作的方法定義一個(gè)類時(shí),首先,要定義它的屬性數(shù)據(jù),其次,要定義對(duì)這些屬性數(shù)據(jù)進(jìn)行操作的方法。類定義的一般格式如下:Class

<類名>{public:<公有成員函數(shù)和數(shù)據(jù)成員的聲明>private:<私有成員函數(shù)或者數(shù)據(jù)成員的聲明>protected:<保護(hù)成員函數(shù)或者數(shù)據(jù)成員的聲明>};<各個(gè)成員函數(shù)的實(shí)現(xiàn)代碼>2.類的定義與對(duì)象生成classQueue{

intQueueMem[100];

//用來存放整型數(shù)據(jù)

intRloc,Sloc;//分別用來指示隊(duì)列的頭與尾

public:

voidInit();

//用來初始化隊(duì)列

voidPut(inti);

//入隊(duì)

intGet();

//出隊(duì)};其中變量QueueMem,Sloc,Rloc是私有變量,之所以稱為私有,意味著它們只能由Queue類的成員函數(shù)來訪問,而不能由程序的其他任何部分來訪問。private,public,protected訪問標(biāo)號(hào)的訪問范圍。private:只能由1.該類中的函數(shù)、2.其友元函數(shù)訪問。不能被任何其他訪問,該類的對(duì)象也不能訪問。protected:可以被1.該類中的函數(shù)、2.子類的函數(shù)、3.其友元函數(shù)訪問。但不能被該類的對(duì)象訪問。public:可以被1.該類中的函數(shù)、2.子類的函數(shù)、3.其友元函數(shù)訪問,4.該類的對(duì)象訪問。2.類的定義與對(duì)象生成實(shí)現(xiàn)一個(gè)類的成員函數(shù),必須通過用類名限定函數(shù)名來告知編譯器這個(gè)函數(shù)屬于哪個(gè)類。例如:voidQueue::Put(inti){

if(Sloc==100)

{

cout<<”Queueisfull”;

return;

}Sloc++;QueueMem[Sloc]=i;}

“::”是作用域運(yùn)算符。它告知編譯器函數(shù)Put()屬于Queue類的,也即它是Queue類的一個(gè)成員函數(shù)。下面是Queue類的完整定義。classQueue{

intQueueMem100];intRloc,Sloc;public:voidInit();voidPut(inti);intGet();};//類Queue的初始化voidQueue::Init(){Rloc=Sloc=0;}//把一個(gè)整數(shù)放入Queue中voidQueue::Put(inti){if(Sloc==100){cout<<"Queueisfull";return;}Sloc++;QueueMem[Sloc]=i;};//從Queue中取出一個(gè)整數(shù)intQueue::Get(){if(Rloc==Sloc){cout<<"Queueisnull";return0;}Rloc++;returnQueueMem[Rloc];}一旦生成了一個(gè)類,類名就成了一種新的數(shù)據(jù)類型標(biāo)識(shí)符,就可以用這個(gè)類名來生成對(duì)象了。例如:

Queue

Q1,Q2;它生成了Queue類的兩個(gè)對(duì)象:Q1和Q2。類相當(dāng)于是用戶創(chuàng)建的一種新的數(shù)據(jù)類型,而對(duì)象只是由類定義的這種數(shù)據(jù)類型的變量而已。一個(gè)類的對(duì)象生成后,就擁有了屬于自己的數(shù)據(jù)副本,如Q1和Q2各自擁有屬于自己的獨(dú)立的QueueMem,Sloc,Rloc數(shù)據(jù)。#include<iostream>usingnamespacestd;//插入上面的Queue類的代碼intmain(){QueueQ1,Q2;//產(chǎn)生兩個(gè)類Queue的對(duì)象

Q1.Init();//Q1初始化Q2.Init();//Q2初始化Q1.Put(10);//把一些整數(shù)分別放入隊(duì)列Q1、Q2中Q1.Put(11);Q2.Put(19);Q2.Put(20);//從隊(duì)列Q1、Q2中分別取出這些整數(shù)cout<<"ContentsofqueueQ1:";cout<<Q1.Get()<<"";cout<<Q1.Get()<<"\n";cout<<"ContentsofqueueQ2:";cout<<Q2.Get()<<"";cout<<Q2.Get()<<"\n";return0;}成員函數(shù)只能相對(duì)于某一個(gè)具體的對(duì)象來調(diào)用。例如:

Q2.Init();在一個(gè)類中,它的一個(gè)成員函數(shù)調(diào)用它的另一個(gè)成員函數(shù)時(shí),可以直接地進(jìn)行,而不必使用點(diǎn)運(yùn)算符。一個(gè)例子classMyclass{inta;public:intb;voidSet_ab(inti);intGet_a();voidReset();};intMyclass::Get_a(){returna;}voidMyclass::Reset(){Set_ab(0);}voidMyclass::Set_ab(inti){a=i;b=i*i;}2.類的定義與對(duì)象生成類的成員在類的外面被引用時(shí),就必須用對(duì)象來限定,并且它們要被聲明為public。成員函數(shù)可直接引用類的其它成員,而不管是否是public還是protectedprivate。類的封裝性(也叫信息隱藏):是把一個(gè)對(duì)象的實(shí)現(xiàn)細(xì)節(jié)從它所提供的服務(wù)中進(jìn)行隱藏,把對(duì)象的外部特征與內(nèi)部細(xì)節(jié)分開。也就是說,外部特征是外部代碼或其它對(duì)象可以訪問的,而內(nèi)部細(xì)節(jié)對(duì)外部代碼或其它對(duì)象來說是隱藏的,它隱藏了一個(gè)對(duì)象是如何工作的。3.構(gòu)造函數(shù)和析構(gòu)函數(shù)構(gòu)造函數(shù):

是在對(duì)象生成時(shí)用來自動(dòng)初始化對(duì)象

是類的一個(gè)成員函數(shù),并與類有同樣的名字構(gòu)造函數(shù)是一個(gè)在對(duì)象被生成的時(shí)候被調(diào)用的函數(shù)構(gòu)造函數(shù)不返回值。析構(gòu)函數(shù)

是在對(duì)象被刪除時(shí)需要它來進(jìn)行一些操作例如,對(duì)象需要把動(dòng)態(tài)分配給它的內(nèi)存釋放析構(gòu)函數(shù)同構(gòu)造函數(shù)同名,但前面加一個(gè)~,析構(gòu)函數(shù)是在對(duì)象被刪除時(shí)自動(dòng)被調(diào)用的函數(shù)析構(gòu)函數(shù)沒有返回類型,無參數(shù)。3一個(gè)例子演示構(gòu)造函數(shù)和析構(gòu)函數(shù)的工作過程。#include<iostream>usingnamespacestd;classQueue{

int*QueueMem;intSloc,Rloc,Maxsize;public:Queue();//構(gòu)造函數(shù)constructor~Queue();//析構(gòu)函數(shù)destructorvoidPut(inti);intGet();};Queue::Queue(intsize){Sloc=Rloc=0;

Maxsize=size;if(!(QueueMem=newint[Maxsize]))exit(0);

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論