C++學(xué)習(xí)筆記之類(lèi)與對(duì)象詳解
前言:
1.C 語(yǔ)言是面向過(guò)程的,關(guān)注的是過(guò)程,分析出求解的步驟,通過(guò)函數(shù)逐步調(diào)用解決問(wèn)題。
2.C++是基于面向?qū)ο蟮?,關(guān)注的是對(duì)象,蔣一件事情拆分成不同的對(duì)象,靠對(duì)象之間的交互完成。
舉個(gè)例子:外賣(mài)系統(tǒng)
面向過(guò)程是下單、接單、送餐的三個(gè)過(guò)程
面向?qū)ο?/strong>:客戶(hù) 商家 騎手 這三個(gè)對(duì)象之間的面向關(guān)系。
1.訪(fǎng)問(wèn)限定符:
用類(lèi)將對(duì)方的屬性與方法結(jié)合在一起,讓對(duì)象更加的完善,通過(guò)訪(fǎng)問(wèn)權(quán)限選擇性的將其接口提供給外部用戶(hù)使用。

1. 我們暫且認(rèn)為 protected 和 private 是一類(lèi),都屬于私有類(lèi)型,在類(lèi)外面不能直接被訪(fǎng)問(wèn)。
2.訪(fǎng)問(wèn)的權(quán)限是從作用域的訪(fǎng)問(wèn)限定符開(kāi)始,到下一個(gè)訪(fǎng)問(wèn)限定符。
3.public修飾成員在類(lèi)外面是可以被訪(fǎng)問(wèn)的
注意:訪(fǎng)問(wèn)限定符只在編譯的時(shí)候有用,當(dāng)數(shù)據(jù)映射到內(nèi)存上時(shí)沒(méi)有任何訪(fǎng)問(wèn)限定符的區(qū)別
【問(wèn)題】C++中 struct和class的區(qū)別是什么?
解答:C++需要兼容C語(yǔ)言,所以C++中的struct可以當(dāng)結(jié)構(gòu)體去使用。另外C++中struct還可以用來(lái)定義類(lèi),和class的定義類(lèi)是一樣的。區(qū)別在于struct的成員默認(rèn)訪(fǎng)問(wèn)方式為public,而class的成員默認(rèn)訪(fǎng)問(wèn)方式是private。
2.封裝
面向?qū)ο蟮娜筇匦裕?strong>封裝、繼承、多態(tài)。
【問(wèn)題】在類(lèi)和對(duì)象的階段,我們只研究類(lèi)的封裝特性,那什么是封裝呢?
封裝:將數(shù)據(jù)和操作數(shù)據(jù)的方法進(jìn)行有機(jī)結(jié)合,隱藏對(duì)象的屬性和實(shí)現(xiàn)細(xì)節(jié),僅對(duì)外公開(kāi)接口來(lái)和對(duì)象進(jìn)行交互。
一句話(huà):封裝的本質(zhì)是管理,隱藏細(xì)節(jié),開(kāi)放接口。
3.類(lèi)的定義與聲明



【問(wèn)題】函數(shù)調(diào)用的問(wèn)題
void Push(STDataType x)
{
// ...
a[size] = x;
size++;
}
// ...
STDataType* a;
int size;
int capacity;
};
int main()
{
//struct Stack st;
Stack st;
st.Init();
st.Push(1);
st.Push(2);
st.Push(3);
return 0;
}
這里的Push是調(diào)用的一個(gè)函數(shù)嗎?
答案:是的,函數(shù)存在公共區(qū)域中的代碼段。

4.類(lèi)的作用域
類(lèi)定義了一個(gè)新的作用域,類(lèi)的所有成員都在類(lèi)的作用域中。在類(lèi)體外定義成員,需要使用 :: 作用域解析符 指明成員屬于哪個(gè)類(lèi)域。
class Person
{
public:
void PrintPersonInfo();
private:
char _name[20];
char _gender[3];
int _age;
};
// 這里需要指定PrintPersonInfo是屬于Person這個(gè)類(lèi)域
void Person::PrintPersonInfo()
{
cout<<_name<<" "_gender<<" "<<_age<<endl; }
5.類(lèi)的實(shí)例化
用類(lèi)類(lèi)型創(chuàng)建對(duì)象的過(guò)程,稱(chēng)為類(lèi)的實(shí)例化
1. 類(lèi)只是一個(gè)模型一樣的東西,限定了類(lèi)有哪些成員,定義出一個(gè)類(lèi)并沒(méi)有分配實(shí)際的內(nèi)存空間來(lái)存儲(chǔ)它。
2. 一個(gè)類(lèi)可以實(shí)例化出多個(gè)對(duì)象,實(shí)例化出的對(duì)象 占用實(shí)際的物理空間,存儲(chǔ)類(lèi)成員變量。
3. 做個(gè)比方。類(lèi)實(shí)例化出對(duì)象就像現(xiàn)實(shí)中使用建筑設(shè)計(jì)圖建造出房子,類(lèi)就像是設(shè)計(jì)圖,只設(shè)計(jì)出需要什么東西,但是并沒(méi)有實(shí)體的建筑存在,同樣類(lèi)也只是一個(gè)設(shè)計(jì),實(shí)例化出的對(duì)象才能實(shí)際存儲(chǔ)數(shù)據(jù),占用物理空間。
Stack s1;
Stack s2;
cout << sizeof(s1) << endl;
cout << sizeof(s2) << endl;
大小遵從內(nèi)存對(duì)齊的原則。
6.類(lèi)的分類(lèi)
class A1 {
public:
void f1(){}
private:
int _a;
};//標(biāo)準(zhǔn)類(lèi)型
// 類(lèi)中僅有成員函數(shù)
class A2 {
public:
void f2() {}
};
// 空類(lèi)
class A3
{};
總結(jié)
本篇文章就到這里了,希望能夠給你帶來(lái)幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
C++使用郵件槽實(shí)現(xiàn)ShellCode跨進(jìn)程傳輸
在計(jì)算機(jī)安全領(lǐng)域,進(jìn)程間通信(IPC)一直是一個(gè)備受關(guān)注的話(huà)題,在本文中,我們將探討如何使用Windows郵件槽(Mailslot)實(shí)現(xiàn)ShellCode的跨進(jìn)程傳輸,需要的可以參考下2023-12-12
C語(yǔ)言近萬(wàn)字為你講透樹(shù)與二叉樹(shù)
樹(shù)是計(jì)算機(jī)算法最重要的非線(xiàn)性結(jié)構(gòu)。因?yàn)闃?shù)能很好地描述結(jié)構(gòu)的分支關(guān)系和層次特性,所以在計(jì)算機(jī)科學(xué)和計(jì)算機(jī)應(yīng)用領(lǐng)域有著廣泛的應(yīng)用。這篇文章我就帶大家一起了解一下樹(shù)、二叉樹(shù)這種結(jié)構(gòu),下篇文章會(huì)重點(diǎn)向大家介紹二叉樹(shù)的遍歷算法2022-05-05
C++實(shí)現(xiàn)校園導(dǎo)游系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)校園導(dǎo)游系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03
C++繼承中的對(duì)象構(gòu)造與析構(gòu)和賦值重載詳解
這篇文章主要為大家詳細(xì)介紹了C++繼承中的對(duì)象構(gòu)造與析構(gòu)和賦值重載,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助2022-03-03
C語(yǔ)言通過(guò)棧實(shí)現(xiàn)小人走迷宮
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言通過(guò)棧實(shí)現(xiàn)小人走迷宮,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03

