Przeładowanie operatorów inkrementacji i dekrementacji (C++)
Operatory inkrementacji i dekrementacji należą do specjalnej kategorii, ponieważ istnieją dwa warianty każdego z nich:
Preinkrementacji i postinkrementacji
Predekrementacji i postdekrementacji
Gdy piszesz funkcje przeciążonych operatorów, może być przydatne, aby zaimplementować ich osobne wersje przedrostkowe i przyrostkowe.Aby je rozróżnić, można zaobserwować następującą regułę: postać przedrostkowa operatora jest deklarowana dokładnie w taki sam sposób, jak dowolny, inny operator jednoargumentowy; postać przyrostkowe przyjmuje dodatkowy argument typu int.
[!UWAGA]
Podczas określania przeciążonego operatora dekrementacji w postaci przyrostkowej, dodatkowy argument musi być typu int; określenie jakiegokolwiek innego typu wygeneruje błąd.
Poniższy przykład pokazuje, w jaki sposób zdefiniować operatory inkrementacji i dekrementacji w postaci przedrostkowej i przyrostkowej dla klasy Point:
// increment_and_decrement1.cpp
class Point
{
public:
// Declare prefix and postfix increment operators.
Point& operator++(); // Prefix increment operator.
Point operator++(int); // Postfix increment operator.
// Declare prefix and postfix decrement operators.
Point& operator--(); // Prefix decrement operator.
Point operator--(int); // Postfix decrement operator.
// Define default constructor.
Point() { _x = _y = 0; }
// Define accessor functions.
int x() { return _x; }
int y() { return _y; }
private:
int _x, _y;
};
// Define prefix increment operator.
Point& Point::operator++()
{
_x++;
_y++;
return *this;
}
// Define postfix increment operator.
Point Point::operator++(int)
{
Point temp = *this;
++*this;
return temp;
}
// Define prefix decrement operator.
Point& Point::operator--()
{
_x--;
_y--;
return *this;
}
// Define postfix decrement operator.
Point Point::operator--(int)
{
Point temp = *this;
--*this;
return temp;
}
int main()
{
}
Takie same operatory mogą być definiowane globalnie, w zakresie pliku, przy użyciu następujących nagłówków funkcji:
friend Point& operator++( Point& ) // Prefix increment
friend Point& operator++( Point&, int ) // Postfix increment
friend Point& operator--( Point& ) // Prefix decrement
friend Point& operator--( Point&, int ) // Postfix decrement
Argument typu int, który oznacza przyrostkową postać operatora inkrementacji lub dekrementacji nie jest powszechnie używany do przekazywania argumentów.Zwykle zawiera wartość 0.Jednakże, może być użyty w następujący sposób:
// increment_and_decrement2.cpp
class Int
{
public:
Int &operator++( int n );
private:
int _i;
};
Int& Int::operator++( int n )
{
if( n != 0 ) // Handle case where an argument is passed.
_i += n;
else
_i++; // Handle case where no argument is passed.
return *this;
}
int main()
{
Int i;
i.operator++( 25 ); // Increment by 25.
}
Nie ma składni przeznaczonej do używania operatorów inkrementacji lub dekrementacji do przekazywania tych wartości inaczej, niż przez jawne wywołanie, jak pokazano w powyższym kodzie.Bardziej bezpośredni sposób implementacji tej funkcji to przeciążenie operatora dodawania/przypisania (+=).