Grand Central Dispatch

Grand Central Dispatch
Basisdaten

HauptentwicklerApple Inc.
EntwicklerApple Inc.
Aktuelle Version1.0
(11. September 2009)
BetriebssystemmacOS, iOS, tvOS, watchOS, Unix
LizenzApache-Lizenz 2.0
deutschsprachignein
libdispatch.macosforge.org

Grand Central Dispatch (GCD) ist eine Softwaretechnologie und eine Programmierschnittstelle, die von Dave Zarzycki beim Unternehmen Apple entwickelt wurde, um die Unterstützung von mehreren Hauptprozessoren bzw. Prozessorkernen durch Abstraktion zu verbessern.[1] Der Quelltext für die Einbindung von Grand-Central-Dispatch-Diensten, libdispatch, wurde am 10. September 2009 von Apple offengelegt.[2]

Grand Central Dispatch wurde ursprünglich entworfen, um Softwareentwicklern unter macOS (ehemals „Mac OS X“), beginnend mit Mac OS X Snow Leopard (10.6, 2009), die Nutzung von mehreren Prozessorkernen zu erleichtern. Dies war nur ein logischer Schritt, nachdem zum Zeitpunkt der Einführung nahezu jeder Apple-Computer mit Mehrkernprozessor vertrieben wurde. Die Grundkonzeption der Technologie ist es, einzelne, zu verarbeitende Aufgaben (Tasks) zu definieren, die dann von GCD verwaltet und auf die verfügbaren Prozessoren verteilt werden. Daraus ergeben sich als Vorteile, dass sich Entwickler für die Implementierung von einfachen parallelen Aufgaben nicht mit den Details von Multithreading auskennen müssen, sowie dass Grand Central Dispatch unabhängig von der Anzahl der Prozessorkerne arbeitet – damit wird der Programmieraufwand für die Entwickler erheblich reduziert.[3]

Grand Central Dispatch beruht auf den gleichen Prinzipien wie auch Microsofts Task Parallel Library für das .Net-Framework, Suns Concurrency API für Java und Intels Threading Building Blocks.

Portierung auf andere Betriebssysteme

Am 26. September 2009 wurde die Verfügbarkeit von libdispatch unter FreeBSD 8.1 bekanntgegeben.[4] Auch MidnightBSD 0.3-CURRENT beinhaltet libdispatch.[5]

Der aktuelle Quelltext des libdispatch-Projektes kompiliert und funktioniert auch unter Linux. Er wurde der Debian-Distribution bereits als Paket vorgeschlagen.[6][7]

Windows wird von zwei Forks unterstützt, die auf opensource.mlba-team.de und Github zu finden sind.[8][9] Es wird angestrebt, libdispatch als ursprünglichen Bestandteil von Cocoa auch in andere Frameworks, wie etwa Qt, einzubinden.[10]

Siehe auch

Weblinks

Einzelnachweise

  1. Apple zeigt Entwicklern Mac OS X Snow Leopard, 9. Juni, 2008, englisch
  2. Libdispatch veröffentlicht 10. September 2009, englischsprachig
  3. WWDC 2008: Neues in Mac OS X Snow Leopard (Memento desOriginals vom 17. Oktober 2008 im Internet Archive)  Info: Der Archivlink wurde automatisch eingesetzt und noch nicht geprüft. Bitte prüfe Original- und Archivlink gemäß Anleitung und entferne dann diesen Hinweis.@1@2Vorlage:Webachiv/IABot/www.roughlydrafted.com, 18. Juni 2008, englisch
  4. GCD libdispatch w/Blocks support working on FreeBSD (Memento desOriginals vom 27. Juli 2011 im Internet Archive)  Info: Der Archivlink wurde automatisch eingesetzt und noch nicht geprüft. Bitte prüfe Original- und Archivlink gemäß Anleitung und entferne dann diesen Hinweis.@1@2Vorlage:Webachiv/IABot/lists.macosforge.org, 26. September 2009, englisch
  5. libdispatch, 14. August 2010, englisch
  6. libdispatch mailing list: "Porting status" (Memento desOriginals vom 11. Juli 2011 im Internet Archive)  Info: Der Archivlink wurde automatisch eingesetzt und noch nicht geprüft. Bitte prüfe Original- und Archivlink gemäß Anleitung und entferne dann diesen Hinweis.@1@2Vorlage:Webachiv/IABot/lists.macosforge.org 10. April 2011, englisch
  7. Paket: libdispatch0
  8. libdispatch mailing list: "libdispatch for Win32" (Memento desOriginals vom 20. August 2011 im Internet Archive)  Info: Der Archivlink wurde automatisch eingesetzt und noch nicht geprüft. Bitte prüfe Original- und Archivlink gemäß Anleitung und entferne dann diesen Hinweis.@1@2Vorlage:Webachiv/IABot/lists.macosforge.org 22. April 2011, englisch
  9. libdispatch mailing list: "Updates regarding the status of libdispatch on Windows" (Memento desOriginals vom 20. August 2011 im Internet Archive)  Info: Der Archivlink wurde automatisch eingesetzt und noch nicht geprüft. Bitte prüfe Original- und Archivlink gemäß Anleitung und entferne dann diesen Hinweis.@1@2Vorlage:Webachiv/IABot/lists.macosforge.org 5. Mai 2011, englisch
  10. Qt Integration, 7. Mai 2013, englisch