In Cocoa, ein Delegierter ist ein Objekt, das ein anderes Objekt aufschiebt, um auf Fragen von Verhalten beeinflussen und informiert über Änderungen in seinem Zustand. Zum Beispiel ist ein UITableViewDelegate verantwortlich für die Beantwortung von Fragen darüber, wie UITableView sich verhalten soll, wenn Selektionen vorgenommen oder Zeilen neu geordnet werden. Es ist das Objekt, das das UITableView fragt, wenn es wissen möchte, wie hoch eine bestimmte Zeile sein soll. Im Model-View-Controller-Paradigma sind Delegaten Controller, und viele Delegierte enden in "Controller".
Das UIApplicationDelegate ist möglicherweise der Delegat für die UIApplication. Die Beziehung ist in Cocoa (Mac) etwas offensichtlicher als in Cocoa Touch (iPhone), da der NSApplication-Delegat das NSApplication-Verhalten direkter steuern kann (verhindert, dass die Anwendung beispielsweise beendet wird). Das iPhone erlaubt nicht viel Kontrolle über die UIApplication. Daher wird das UIApplicationDelegate hauptsächlich über Änderungen informiert, anstatt einen aktiven Entscheidungsprozess zu führen.
Das UIApplicationDelegate ist nicht überall in der App verfügbar. Die Singleton UIApplication ist ([UIApplication sharedApplication]) und durch sie können Sie ihren Delegaten finden. Dies bedeutet jedoch nicht, dass es für jedes Objekt in einer App angemessen ist, direkt mit dem App-Delegaten zu kommunizieren. Im Allgemeinen rate ich Entwicklern davon ab, zufällige Objekte mit dem App-Delegaten zu sprechen. Die meisten Probleme, die auf diese Weise gelöst werden, werden besser durch Singletons, NSNotification oder andere delegierte Objekte gelöst.
In Bezug auf die Erstellung, auf dem Mac gibt es nichts Magisches über den App-Delegaten. Es ist nur ein Objekt, das in den meisten Fällen von der NIB instanziiert und verdrahtet wird. Auf dem iPhone kann der Anwendungsdelegat jedoch leicht magisch sein, wenn er von UIApplicationMain() instanziiert wird. Der vierte Parameter ist ein NSString, der die Klasse des Anwendungsdelegaten angibt, und UIApplicationMain() erstellt einen und legt ihn als den Delegaten der sharedApplication fest. Auf diese Weise können Sie den Delegaten ohne NIB einrichten (etwas sehr Schwieriges auf dem Mac). Wenn der vierte Parameter für UIApplicationMain() gleich Null ist (wie in den Apple-Vorlagen), wird der Delegat genauso wie das Hauptfenster von der Haupt-NIB erstellt und verdrahtet.
Danke für die Einsicht, Rob! Sicher, dass du kein Top-Apple-Ingenieur bist? ;) – Thanks