C++中的對象數(shù)組詳細解析
類是對象的抽象,我們可以使用一個類來定義很多的對象,然后每個對象都有自己的屬性。
當我們使用類來定義很多相同結構的對象的時候,我們可以采取對象數(shù)組的方法。
例如,一個班有50個學生,我們定義了一個學生類,該類的學生具有相同的數(shù)據(jù)成員和成員函數(shù),我們就可以定義一個這樣的數(shù)組。
Student stdu[50];//假設已經(jīng)聲明了Student類,定義stud數(shù)組,有50個元素
======================對象數(shù)組的初始化=========================
在建立數(shù)組時,同樣要調用構造函數(shù)。如果有50個元素,就需要調用50次構造函數(shù)。在需要的時候,可以在定義數(shù)組時提供實參以實現(xiàn)初始化。
如果構造函數(shù)只有一個參數(shù)可以這樣初始化:
Studet stud[3]={60,70,80};//三個實參分別傳遞給3個數(shù)組元素的構造函數(shù)
如果構造函數(shù)有多個參數(shù)時,應該這樣做:
Student stud[3]={//假設構造函數(shù)有3個參數(shù)
Student(10,20,30),//調用第一個元素的構造函數(shù),提供3個實參
Student(40,50,60),//調用第二個元素的構造函數(shù),提供3個實參
Student(70,80,90) //調用第三個元素的構造函數(shù),提供3個實參
};
在建立對象數(shù)組時,分別調用構造函數(shù),對每個元素初始化。每一個元素的實參分別用括號括起來,對應構造函數(shù)的一組形參。
===================一個對象數(shù)組的例子=================
要求:建立一個對象數(shù)組,內放5個學生的數(shù)據(jù)(學號,成績),設立一個函數(shù)max,在max函數(shù)中找出5個學生中成績最高者,并出輸出結果。
#include<iostream>
#include<string>
using namespace std;
class Student
{
public:
Student(string , int );//聲明構造函數(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++中求旋轉數(shù)組中的最小數(shù)字(經(jīng)典面試題)
- C++按照正態(tài)分布來排列整型數(shù)組元素
- c++將數(shù)組名作為函數(shù)參數(shù)對數(shù)組元素進行相應的運算
- C/C++中獲取數(shù)組長度的方法示例
- C++結構體數(shù)組詳細解析
- C++指針數(shù)組、數(shù)組指針、數(shù)組名及二維數(shù)組技巧匯總
- C++動態(tài)數(shù)組類的封裝實例
- 深入解析C++中的字符數(shù)組和處理字符串的方法
- 詳解C++中的一維數(shù)組和二維數(shù)組
- C++對數(shù)組的引用實例分析
- C++實現(xiàn)從數(shù)組中同時取出最大最小元素算法示例
相關文章
PyQt5利用Qt Designer實現(xiàn)簡單界面交互
本文主要介紹了PyQt5利用Qt Designer實現(xiàn)簡單界面交互,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2025-03-03

