Udostępnij za pośrednictwem


Tworzenie indeksów dolnych

Operator indeksu dolnego ([]), taki jak operator wywołania funkcji, jest uważany za operator binarny.Operator indeksu dolnego musi być niestatycznym elementem członkowskim funkcji, który pobiera jeden argument.Ten argument może być dowolnego typu i wyznacza indeks dolny żądanej tablicy.

Przykład

Poniższy przykład ilustruje sposób tworzenia wektorów typu int , które implementują sprawdzanie zakresu:

// subscripting.cpp
// compile with: /EHsc
#include <iostream>

using namespace std;
class IntVector {
public:
   IntVector( int cElements );
   ~IntVector() { delete [] _iElements; }
   int& operator[]( int nSubscript );
private:
   int *_iElements;
   int _iUpperBound;
};

// Construct an IntVector.
IntVector::IntVector( int cElements ) {
   _iElements = new int[cElements];
   _iUpperBound = cElements;
}

// Subscript operator for IntVector.
int& IntVector::operator[]( int nSubscript ) {
   static int iErr = -1;

   if( nSubscript >= 0 && nSubscript < _iUpperBound )
      return _iElements[nSubscript];
   else {
      clog << "Array bounds violation." << endl;
      return iErr;
   }
}

// Test the IntVector class.
int main() {
   IntVector v( 10 );
   int i;

   for( i = 0; i <= 10; ++i )
      v[i] = i;

   v[3] = v[9];

   for ( i = 0; i <= 10; ++i )
      cout << "Element: [" << i << "] = " << v[i] << endl;
}
  

Komentarze

Gdy osiąga i 10 w poprzednim programie, operator[] wykrywa, że dolna luka jest używana i wysyła komunikat o błędzie.

Należy zauważyć, że funkcja operator[] zwraca typ referencyjny.To powoduje, że l-wartość umożliwia używanie wyrażeń po obu stronach operatora przypisania.

Zobacz też

Informacje

Przeładowanie operatora