C++中的對(duì)象數(shù)組詳細(xì)解析
類(lèi)是對(duì)象的抽象,我們可以使用一個(gè)類(lèi)來(lái)定義很多的對(duì)象,然后每個(gè)對(duì)象都有自己的屬性。
當(dāng)我們使用類(lèi)來(lái)定義很多相同結(jié)構(gòu)的對(duì)象的時(shí)候,我們可以采取對(duì)象數(shù)組的方法。
例如,一個(gè)班有50個(gè)學(xué)生,我們定義了一個(gè)學(xué)生類(lèi),該類(lèi)的學(xué)生具有相同的數(shù)據(jù)成員和成員函數(shù),我們就可以定義一個(gè)這樣的數(shù)組。
Student stdu[50];//假設(shè)已經(jīng)聲明了Student類(lèi),定義stud數(shù)組,有50個(gè)元素
======================對(duì)象數(shù)組的初始化=========================
在建立數(shù)組時(shí),同樣要調(diào)用構(gòu)造函數(shù)。如果有50個(gè)元素,就需要調(diào)用50次構(gòu)造函數(shù)。在需要的時(shí)候,可以在定義數(shù)組時(shí)提供實(shí)參以實(shí)現(xiàn)初始化。
如果構(gòu)造函數(shù)只有一個(gè)參數(shù)可以這樣初始化:
Studet stud[3]={60,70,80};//三個(gè)實(shí)參分別傳遞給3個(gè)數(shù)組元素的構(gòu)造函數(shù)
如果構(gòu)造函數(shù)有多個(gè)參數(shù)時(shí),應(yīng)該這樣做:
Student stud[3]={//假設(shè)構(gòu)造函數(shù)有3個(gè)參數(shù)
Student(10,20,30),//調(diào)用第一個(gè)元素的構(gòu)造函數(shù),提供3個(gè)實(shí)參
Student(40,50,60),//調(diào)用第二個(gè)元素的構(gòu)造函數(shù),提供3個(gè)實(shí)參
Student(70,80,90) //調(diào)用第三個(gè)元素的構(gòu)造函數(shù),提供3個(gè)實(shí)參
};
在建立對(duì)象數(shù)組時(shí),分別調(diào)用構(gòu)造函數(shù),對(duì)每個(gè)元素初始化。每一個(gè)元素的實(shí)參分別用括號(hào)括起來(lái),對(duì)應(yīng)構(gòu)造函數(shù)的一組形參。
===================一個(gè)對(duì)象數(shù)組的例子=================
要求:建立一個(gè)對(duì)象數(shù)組,內(nèi)放5個(gè)學(xué)生的數(shù)據(jù)(學(xué)號(hào),成績(jī)),設(shè)立一個(gè)函數(shù)max,在max函數(shù)中找出5個(gè)學(xué)生中成績(jī)最高者,并出輸出結(jié)果。
#include<iostream>
#include<string>
using namespace std;
class Student
{
public:
Student(string , int );//聲明構(gòu)造函數(shù)
void Print();//聲明信息輸出函數(shù)
string num;
int score;
};
Student::Student(string n,int s)
{
num=n;
score=s;
}
void Student::Print()
{
cout<<num<<"\t"<<score<<endl;
}
int main()
{
Student stud[5]={
Student("001",90),
Student("002",94),
Student("003",70),
Student("004",100),
Student("005",60)
};
int max,i=0,k=0;
max=stud[0].score;
for(i=0;i<5;i++)
{
cout<<stud[i].num<<"\t"<<stud[i].score<<endl;
if(stud[i].score>max)
{
k=i;
max=stud[i].score;
}
}
cout<<"=============MAX:==========="<<endl;
stud[k].Print();
cout<<endl;
}

- C++中求旋轉(zhuǎn)數(shù)組中的最小數(shù)字(經(jīng)典面試題)
- C++按照正態(tài)分布來(lái)排列整型數(shù)組元素
- c++將數(shù)組名作為函數(shù)參數(shù)對(duì)數(shù)組元素進(jìn)行相應(yīng)的運(yùn)算
- C/C++中獲取數(shù)組長(zhǎng)度的方法示例
- C++結(jié)構(gòu)體數(shù)組詳細(xì)解析
- C++指針數(shù)組、數(shù)組指針、數(shù)組名及二維數(shù)組技巧匯總
- C++動(dòng)態(tài)數(shù)組類(lèi)的封裝實(shí)例
- 深入解析C++中的字符數(shù)組和處理字符串的方法
- 詳解C++中的一維數(shù)組和二維數(shù)組
- C++對(duì)數(shù)組的引用實(shí)例分析
- C++實(shí)現(xiàn)從數(shù)組中同時(shí)取出最大最小元素算法示例
相關(guān)文章
udp socket客戶端和udp服務(wù)端程序示例分享
這篇文章主要介紹了udp socket客戶端和udp服務(wù)端程序示例,需要的朋友可以參考下2014-03-03Qt creator中項(xiàng)目的構(gòu)建配置和運(yùn)行設(shè)置的步驟
使用 Qt Creator 集成開(kāi)發(fā)環(huán)境構(gòu)建和運(yùn)行程序是一件非常簡(jiǎn)單的事情,一個(gè)按鈕或者一個(gè)快捷鍵搞定全部,本文主要介紹了Qt creator中項(xiàng)目的構(gòu)建配置和運(yùn)行設(shè)置的步驟,感興趣的小伙伴們可以參考一下2021-11-11C語(yǔ)言實(shí)現(xiàn)掃雷游戲詳細(xì)代碼
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)掃雷游戲的具體步驟和詳細(xì)代碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-11-11劍指offer之C++語(yǔ)言實(shí)現(xiàn)鏈表(兩種刪除節(jié)點(diǎn)方式)
今天小編就為大家分享一篇關(guān)于劍指offer之C++語(yǔ)言實(shí)現(xiàn)鏈表(兩種刪除節(jié)點(diǎn)方式),小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2019-02-02