favor considere siguiente códigosobrecarga de operadores de sufijo y el prefijo
#include <iostream>
using namespace std;
class Digit
{
private:
int m_digit;
public:
Digit(int ndigit=0){
m_digit=ndigit;
}
Digit& operator++();//prefix
Digit& operator--(); //prefix
Digit operator++(int);
Digit operator--(int);
int get() const { return m_digit;}
};
Digit& Digit::operator++(){
++m_digit;
return *this;
}
Digit& Digit::operator--(){
--m_digit;
return *this;
}
Digit Digit::operator++(int){
Digit cresult(m_digit);
++(*this);
return cresult;
}
Digit Digit::operator--(int){
Digit cresult(m_digit);
--(*this);
return cresult;
}
int main(){
Digit cDigit(5);
++cDigit;
cDigit++;
cout<<cDigit.get()<<endl;
cout<<cDigit.get()<<endl;
return 0;
}
aquí se implementa dos versiones de operadores de sufijo y el prefijo, he leído esa diferencia se hace por introducir otro llamado argumento ficticio, pero tengo pregunta si vemos declaración de estos
Digit& operator++();//prefix
Digit& operator--(); //prefix
Digit operator++(int);
Digit operator--(int);
que se diferenciaban por & marca, así que por qué es necesaria argumento ficticio? y también en ambos casos, por ejemplo, el operador ++ está escrito antes de la vista y no significa que sean ¿mismo?
Imagino que hay una anotación en el brazo o en alguna parte de por qué este fue el método elegido para la desambiguación. La respuesta es probablemente tan simple como "no había otra manera". –