Въвеждането на клас масив от C ++ 11 предложи по-добра алтернатива за масиви в стил C. Предимствата на класа на масива над масив в стил C са:-
- Класовете за масиви знаят собствения си размер, докато масивите в стил C липсва това свойство. Така че, когато преминаваме към функции, няма нужда да предаваме размер на масива като отделен параметър.
- С масив от стил C има повече риск от масив се разпада в показалец . Класовете за масиви не се разпадат в указатели
- Класовете за масиви обикновено са по-ефективни светлинни и надеждни от масивите в стил C.
Операции на масив :-
1. At () :- Тази функция се използва за достъп до елементите на масива.
2. Get () :- Тази функция се използва и за достъп до елементите на масива. Тази функция не е член на класа на масива, а претоварена функция от корпус от клас.
3. Оператор [] :- Това е подобно на масиви в стил C. Този метод се използва и за достъп до елементи на масива.
CPP
// C++ code to demonstrate working of array // at() and get() #include #include // for array at() #include // for get() using namespace std; int main() { // Initializing the array elements array<int6> ar = {1 2 3 4 5 6}; // Printing array elements using at() cout << 'The array elements are (using at()) : '; for ( int i=0; i<6; i++) cout << ar.at(i) << ' '; cout << endl; // Printing array elements using get() cout << 'The array elements are (using get()) : '; cout << get<0>(ar) << ' ' << get<1>(ar) << ' '; cout << get<2>(ar) << ' ' << get<3>(ar) << ' '; cout << get<4>(ar) << ' ' << get<5>(ar) << ' '; cout << endl; // Printing array elements using operator[] cout << 'The array elements are (using operator[]) : '; for ( int i=0; i<6; i++) cout << ar[i] << ' '; cout << endl; return 0; }
Изход
The array elements are (using at()) : 1 2 3 4 5 6 The array elements are (using get()) : 1 2 3 4 5 6 The array elements are (using operator[]) : 1 2 3 4 5 6
4. Front () :- Това връща препратка към първия елемент на масива.
5. Назад () :- Това връща препратка към последния елемент на масива.
// C++ code to demonstrate working of // front() and back() #include #include // including header file to use stl array and there function using namespace std; int main() { // Initializing the array elements array<int6> ar = {1 2 3 4 5 6}; // Printing first element of array cout << 'First element of array is : '; int &a=ar.front(); cout <<a<< endl; // Printing last element of array cout << 'Last element of array is : '; int &b=ar.back(); cout << b << endl; //change first and last element of array using these references a=10; //now 1 change to 10 b=60; //now 6 change to 60 //lets print array now cout<<'array after updating first and last element n'; for (auto x: ar) { cout<<x<<' '; } cout<<endl; return 0; }
Изход
First element of array is : 1 Last element of array is : 6 array after updating first and last element 10 2 3 4 5 60
6. Размер () :- Връща броя на елементите в масива. Това е свойство, на което липсват масиви в стил C.
7. max_size () :- Връща максималния брой елементи, които масивът може да държи, т.е. размера, с който е деклариран масив. Размерът () и max_size () връщат същата стойност.
// C++ code to demonstrate working of // size() and max_size() #include #include // for size() and max_size() using namespace std; int main() { // Initializing the array elements array<int6> ar = {1 2 3 4 5 6}; // Printing number of array elements cout << 'The number of array elements is : '; cout << ar.size() << endl; // Printing maximum elements array can hold cout << 'Maximum elements array can hold is : '; cout << ar.max_size() << endl; return 0; }
Изход
The number of array elements is : 6 Maximum elements array can hold is : 6
8. swap () :- Смяната () разменя всички елементи на един масив с друг.
CPP
// C++ code to demonstrate working of swap() #include #include // for swap() and array using namespace std; int main() { // Initializing 1st array array<int6> ar = {1 2 3 4 5 6}; // Initializing 2nd array array<int6> ar1 = {7 8 9 10 11 12}; // Printing 1st and 2nd array before swapping cout << 'The first array elements before swapping are : '; for (int i=0; i<6; i++) cout << ar[i] << ' '; cout << endl; cout << 'The second array elements before swapping are : '; for (int i=0; i<6; i++) cout << ar1[i] << ' '; cout << endl; // Swapping ar1 values with ar ar.swap(ar1); // Printing 1st and 2nd array after swapping cout << 'The first array elements after swapping are : '; for (int i=0; i<6; i++) cout << ar[i] << ' '; cout << endl; cout << 'The second array elements after swapping are : '; for (int i=0; i<6; i++) cout << ar1[i] << ' '; cout << endl; return 0; }
Изход
The first array elements before swapping are : 1 2 3 4 5 6 The second array elements before swapping are : 7 8 9 10 11 12 The first array elements after swapping are : 7 8 9 10 11 12 The second array elements after swapping are : 1 2 3 4 5 6
9. празно () :- Тази функция връща True, когато размерът на масива е нулев друг връща невярно.
10. Fill () :- Тази функция се използва за запълване на целия масив с определена стойност.
// C++ code to demonstrate working of empty() // and fill() #include #include // for fill() and empty() using namespace std; int main() { // Declaring 1st array array<int6> ar; // Declaring 2nd array array<int0> ar1; // Checking size of array if it is empty ar1.empty()? cout << 'Array empty': cout << 'Array not empty'; cout << endl; // Filling array with 0 ar.fill(0); // Displaying array after filling cout << 'Array after filling operation is : '; for ( int i=0; i<6; i++) cout << ar[i] << ' '; return 0; }
Изход
Array empty Array after filling operation is : 0 0 0 0 0 0