本帖最后由 51黑黑黑 于 2016-2-12 19:01 編輯
類是具體對象(實例)的抽象。那么究竟如何抽象?就是把一個實例的特征提取出來,比如,水果是一個類,蘋果是水果的一個實例,蘋果有蘋果的特征,其他水果有其他水果的特征,比如香蕉。我們只要從蘋果香蕉中把特征提取出來進行統(tǒng)一管理就可以,這樣就形成了水果類classFruits()。然后“Fruites apple”,表示蘋果是水果的一個實例。就像人如果是一個類的話,我們每一個人都是這個類的實例。 構(gòu)造函數(shù)最重要的作用是創(chuàng)建對象本身。C++規(guī)定,每個類必須有一個構(gòu)造函數(shù),沒有構(gòu)造函數(shù),就不能創(chuàng)建任何對象。 C++又規(guī)定,如果一個類沒有提供任何的構(gòu)造函數(shù),則C++提供一個默認(rèn)的構(gòu)造函數(shù)(由C++編譯器提供),這個默認(rèn)的構(gòu)造函數(shù)是一個不帶參數(shù)的構(gòu)造函數(shù),它只負(fù)責(zé)創(chuàng)建對象,而不做任何的初始化工作。只要一個類定義了一個構(gòu)造函數(shù),不管這個構(gòu)造函數(shù)是否是帶參數(shù)的構(gòu)造函數(shù),C++就不再提供默認(rèn)的構(gòu)造函數(shù)。也就是說,如果為一個類定義了一個帶參數(shù)的構(gòu)造函數(shù),還想要無參數(shù)的構(gòu)造函數(shù),則必須自己定義。
當(dāng)一個對象生命周期結(jié)束時,其所占有的內(nèi)存空間就要被回收,這個工作就由析構(gòu)函數(shù)來完成。 析構(gòu)函數(shù)是“反向”的構(gòu)造函數(shù),析構(gòu)函數(shù)不允許有返回值,更重要的是析構(gòu)函數(shù)不允許帶參數(shù),并且一個類中只能有一個析構(gòu)函數(shù)。析構(gòu)函數(shù)的作用正好與構(gòu)造函數(shù)相反,對象超出其作用范圍,對應(yīng)的內(nèi)存空間被系統(tǒng)收回或被程序用delete刪除時,析構(gòu)函數(shù)被調(diào)用。 根據(jù)析構(gòu)函數(shù)的這種特點,我們可以在構(gòu)造函數(shù)中初始化對象的某些成員變量,給其分配內(nèi)存空間(堆內(nèi)存),在析構(gòu)函數(shù)中釋放對象運行期間所申請的資源。
如圖所示,CTextView類中的構(gòu)造函數(shù)是CTextView(),析構(gòu)函數(shù)為~CTextView()。
重載函數(shù)是函數(shù)的一種特殊情況,為方便使用,C++允許在同一范圍中聲明幾個功能類似的函數(shù)同名,但是這些同名函數(shù)的形式參數(shù)(指參數(shù)的個數(shù)、類型或者順序)必須不同,也就是說用同一個運算符完成不同的運算功能。這就是重載函數(shù)。重載函數(shù)常用來實現(xiàn)功能類似而所處理的數(shù)據(jù)類型不同的問題。 兩個重載函數(shù)必須在下列一個或兩個方面有所區(qū)別: 1.、函數(shù)有不同參數(shù)。 2、函數(shù)有不同參數(shù)類型, 第一種情況,假設(shè)一個對象為cc,那么cc調(diào)用兩個函數(shù)都為cc.output(),編譯器無法分辨是哪一種,所以不能構(gòu)成重載;第二種情況,由于b已經(jīng)被設(shè)為缺省值5,而且另一個參數(shù)相同,所以也不能構(gòu)成重載。
VC++(一)標(biāo)準(zhǔn)輸入輸出
VC++6.0標(biāo)準(zhǔn)輸入輸出流庫函數(shù)iostream常用的輸入和輸出函數(shù)為cin和cout,下面用一個簡單的例程來說明
#include <iostream.h>
int main()
{
cout<<"Enter twonumbers:"<<endl;
int v1,v2;
cin>>v1>>v2;
cout<<"The sum of"<<v1<<"+"<<v2<<"="<<v1+v2<<endl;
return 0;
}
cout后面跟左書名號,代表輸出
endl表示換行
cin后面跟右書名號,代表輸入
VC++(二)MFC AppWizard初步
首先建立一個MFC AppWizard工程,工程名Test如下圖所示

建立完成后,會出現(xiàn)如上圖所示的視圖,在類視圖中CMainFrame的名字是不會變的,而APP、Doc、View是以C+工程名+類的方式出現(xiàn)的?梢钥吹,在上面工程中并未找到入口函數(shù)WinMain,其實它的位置在安裝目錄下VC98\MFC\SRC里面的APPMODUL.CPP中,如下圖所示:
事實上,_tWinMain是個宏,直接右鍵轉(zhuǎn)到定義出就會發(fā)現(xiàn)#define_tWinMain WinMain這樣一個宏定義。我們在_tWinMain函數(shù)這里設(shè)置一個斷點并調(diào)試運行,就會發(fā)現(xiàn)程序確實在這里停了,說明進入了這個函數(shù)。
接下來一個比較重要的問題是全局對象CTestApp

CTestApp是從CWinApp派生出來的一個類,而theApp是CTestApp實例化的一個對象,它唯一地表示應(yīng)用程序本身。CTestApp()導(dǎo)致CWinApp::CWinApp(LPCTSTRlpszAppName)的調(diào)用,這個函數(shù)主要做程序運行前的初始化工作。
VC++(三)指向指針的指針如下例所示
#include "iostream.h"
int ival=1024;
int *pi=&ival;
int **ppi=π
int a[5]={3,8,7,6,5};
int *pa=a;
const size_t arr_sz=5;
int main()
{
cout<<"ival is"<<ival<<"\n"
<<"&ival is"<<&ival<<"\n"
<<"*pi is"<<*pi<<"\n"
<<"pi is"<<pi<<"\n"
<<"**ppiis"<<**ppi<<"\n"
<<"*ppiis"<<*ppi<<"\n"
<<"ppiis"<<ppi<<"\n"
<<"ais"<<a<<"\n"
<<"pais"<<pa<<"\n"
<<"*pais"<<*pa<<"\n";
pa=&a[2];
cout<<"pais"<<pa<<"\n"
<<"*pais"<<*pa<<"\n";
pa=a+1;
cout<<"pais"<<pa<<"\n"
<<"*pais"<<*pa<<"\n";
for(int *pbegin=a,*pend=pbegin+arr_sz; pbegin!=pend;++pbegin)
{
cout<<pbegin<<""
<<*pbegin<<"\n";
}
return 0;
運行結(jié)果如下圖所示

顯然指針變量pi保存的是變量ival的地址,ppi實際上保存的是pi的地址,那么*ppi就是pi的值(即ival的地址),**ppi就是ival的值。
而指向數(shù)組的指針pa=a+1后,實際上指向了下一個元素
|