Das folgende Code-Beispiel stammt aus dem Buch
Objektorientiertes Programmieren in C++
- Ein Tutorial für Ein- und Umsteiger
von Nicolai Josuttis, Addison-Wesley München, 2001
© Copyright Nicolai Josuttis 2001
#ifndef BRUCH_HPP
#define BRUCH_HPP
// Standard-Headerdateien einbinden
#include <iostream>
// **** BEGINN Namespace Bsp ********************************
namespace Bsp {
class Bruch {
protected:
int zaehler;
int nenner;
public:
/* Fehlerklasse
*/
class NennerIstNull {
};
/* Default-Konstruktor, Konstruktor aus Zähler und
* Konstruktor aus Zähler und Nenner
*/
Bruch (int = 0, int = 1);
/* Multiplikation
* - globale Friend-Funktion, damit eine automatische
* Typumwandlung des ersten Operanden möglich ist
*/
friend Bruch operator * (const Bruch&, const Bruch&);
/* multiplikative Zuweisung
* - neu: virtuell
*/
virtual const Bruch& operator *= (const Bruch&);
/* Vergleich
* - globale Friend-Funktion, damit eine automatische
* Typumwandlung des ersten Operanden möglich ist
*/
friend bool operator < (const Bruch&, const Bruch&);
/* Ein- und Ausgabe mit Streams
* - neu: virtuell
*/
virtual void printOn (std::ostream&) const;
virtual void scanFrom (std::istream&);
/* Typumwandlung nach double
* - neu: virtuell
*/
virtual double toDouble () const;
// neu: virtueller Destruktor (ohne Anweisungen)
virtual ~Bruch () {
}
};
/* Operator *
* - globale Friend-Funktion
* - inline definiert
*/
inline Bruch operator * (const Bruch& a, const Bruch& b)
{
/* Zähler und Nenner einfach multiplizieren
* - das Kürzen sparen wir uns
*/
return Bruch (a.zaehler * b.zaehler, a.nenner * b.nenner);
}
/* Standard-Ausgabeoperator
* - global überladen und inline definiert
*/
inline
std::ostream& operator << (std::ostream& strm, const Bruch& b)
{
b.printOn(strm); // Elementfunktion zur Ausgabe aufrufen
return strm; // Stream zur Verkettung zurückliefern
}
/* Standard-Eingabeoperator
* - global überladen und inline definiert
*/
inline
std::istream& operator >> (std::istream& strm, Bruch& b)
{
b.scanFrom(strm); // Elementfunktion zur Eingabe aufrufen
return strm; // Stream zur Verkettung zurückliefern
}
} // **** ENDE Namespace Bsp ********************************
#endif // BRUCH_HPP