Edit: ein anderes Beispiel wäre das
Null-Objekt Pattern. Viel schöner als Fehlerbehandlungscode ist doch, wenn man einfach mit den Objekten arbeiten kann, die man als Rückgabe bekommt, und einfach genau das passiert, was passieren soll, wenn man Methoden dieser Objekte aufruft.
Das spricht doch eigentlich gegen eine Try-Klasse und für Exceptions
nehmen wir an ich habe eine Methode
Wenn ich mit Exceptions arbeite weiß ich, dass wenn ich bspw.
aufrufe und keine
Exception geworfen wird (und myUrl somit als zugewiesen gilt), ich in myUrl eine wunderschöne
Url-Instanz habe. Wenn ich hingegen eine Try-Klasse oder Fehlermeldungen durch Rückgabewerte oder CallByReference-Parameter verwende, was habe ich dann in myUrl? Vielleicht ne
Url, vielleicht aber auch nicht.
Ein
Null-Objekt setzt man auch nicht ein, um eine
Exception-Behandlung zu ersetzen, sondern, da wo es passt, um den Code einfacher zu halten.
Denn ständig zu prüfen, ob es das Objekt gibt oder nicht um, wenn ja, es dann zu benutzen ist dann etwas umständlich.
Vor allem, wenn dann dieses Objekt auch noch von aussen angesprochen werden soll.
Delphi-Quellcode:
ILogger = interface
procedure Log( const Text : string );
end;
TFoo = class
private
FLogger : ILogger;
function GetLogger : ILogger;
procedure SetLogger( const Value : ILogger );
public
property Logger : ILogger read Getlogger write SetLogger;
procedure Bar;
end;
implementation
type
TNullLogger = class( TInterfacedObject, ILogger )
procedure Log( const Text : string );
end;
procedure TNullLogger.Log( const Text : string );
begin
// do nothing
end;
procedure TFoo.SetLogger( const Value : ILogger );
begin
FLogger := Value;
end;
function TFoo.GetLogger : Ilogger;
begin
if not Assigned( Flogger ) then
FLogger := TNullLogger.Create;
Result := Flogger;
end;
procedure TFoo.Bar;
begin
Logger.Log( 'Bar from TFoo Start' );
Logger.Log( 'Bar from TFoo Step 1' );
Logger.Log( 'Bar from TFoo Step 2' );
Logger.Log( 'Bar from TFoo Step 3' );
Logger.Log( 'Bar from TFoo Stop' );
end;
end.
Als Logger kann ich jetzt also irgendwas dort unterjubeln, allerdings kann ich zum Ausschalten des Loggens einfach ein
nil
übergeben, und trotzdem knallt es nicht, es wird aber auch nichts geloggt.