Inversion of Control
Der Begriff Inversion of Control (IOC; deutsch: „Umkehrung der Steuerung“) bezeichnet ein Umsetzungsparadigma, das in der Objektorientierten Programmierung Anwendung findet.
Dieses Paradigma beschreibt die Arbeitsweise von Frameworks: eine Funktion eines Anwendungsprogramms wird bei einer Standardbibliothek registriert, und von dieser zu einem späteren Zeitpunkt aufgerufen. Das wird manchmal als eine Anwendung des „Hollywood-Prinzips“ bezeichnet: "don't call us, we'll call you" (zu deutsch: „Rufen Sie uns nicht an, wir rufen Sie an“): statt dass die Anwendung den Kontrollfluss steuert und lediglich Standardfunktionen benutzt, wird die Steuerung der Ausführung bestimmter Unterprogramme an das Framework abgegeben.
Somit funktionieren fast alle modernen Programmiersprachen nach dem Prinzip Inversion of Control: Ein vordefiniertes Framework bildet das Hauptprogramm. Der Programmierer hat keinen/ wenig Einfluss auf die Steuerung diese Hauptprogramms. Er kann nur bestimmte Funktion implementieren. Diese werden dann durch das Framework aufgerufen. Dies steht im Gegensatz zum klassischen Programmieransatz, bei dem der Programmierer das Hauptprogramm selber schreibt und einzelne Funktionen aufruft, die aus einer Bibliothek stammen. Im klassischen Ansatz ist die Kontrolle hauptsächlich in dem vom Programmierer erstellten Programm. Diese wird kurzzeitig an andere Vordefinierte Funktionen abgegeben. Bei Inversion of Control liegt die Kontrolle hauptsächlich im Framework, welches dann eine Funktion des Programmierers aufruft und somit kurzzeitig die Kontrolle an diese abgibt.
Inversion of Control ist besonders in der Programmiersprache Java verbreitet. Ein einfaches Beispiel einer solchen Umkehrung sind Listener (gemäß dem Beobachter-Muster), aber auch Applets und Servlets folgen diesem Entwurfsmuster. Plugins und Rückruffunktionen sind weitere Beispiele dafür, die Steuerung einzelner Programmteile einem Framework zu überlassen.
Häufig ist auch bei Containern, die mit Dependency Injection arbeiten, von Inversion of Control zu lesen, hier geht es aber vorwiegend um die Erzeugung von Objektnetzen. (s.a. Fabrikmuster)