Problemorientierte Programmiersprache

Problemorientierte Programmiersprache

Eine domänenspezifische Sprache (engl. domain-specific language, DSL) ist eine formale Sprache, die speziell für ein bestimmtes Problemfeld (die Domäne) entworfen und implementiert wird. Beim Entwurf einer DSL wird man bemüht sein, einen hohen Grad an Problemspezifität zu erreichen: die Sprache soll alle Probleme der Domäne darstellen können und nichts darstellen können, was außerhalb der Domäne liegt. Dadurch ist sie durch Domänenspezialisten ohne besonderes Zusatzwissen bedienbar.

Das Gegenteil ist eine universell einsetzbare Programmiersprache, wie C und Java, oder eine universell einsetzbare Modellierungssprache, wie UML.

Inhaltsverzeichnis

Vorteile

Zu den Vorteilen einer DSL gegenüber der Nutzung einer allgemeinen Programmier- oder Spezifikationssprache zählen

  • weniger Redundanz
  • deklarative Beschreibung eines Sachverhaltes
  • bessere Lesbarkeit
  • weniger technische Code
  • domänenspezifische statische Validierung (nur externe DSLs)
  • leichte Erlernbarkeit, aufgrund des beschränkten Umfangs

Auch Endbenutzer können DSLs verwenden, da diese leichter erlernt werden können als universell einsetzbare Programmiersprachen. Man spricht hier von End User Development.

Nachteile

  • Aufwand der Erlernung einer neuen Sprache bei einem verhältnismäßig eingeschränkten Anwendungsbereich der Sprache
  • Aufwand der Implementierung und Pflege der neuen Sprache und der Tools, die zur Definition der Sprache benötigt werden
  • Schwierigkeit der Findung des geeigneten Abstraktionsniveaus

Arten von DSLs

Man unterscheidet zwischen internen (eingebetteten) DSLs und externen DSLs.

Interne / eingebettete DSLs (internal DSL)

Eine interessante Untermenge domänenspezifischer Sprachen stellen die internen DSLs (engl. internal DSL oder auch embedded domain specific language) dar, die wesentliche Komponenten der Sprachimplementierung ihrer Wirtsprache nutzen. Dadurch sinkt der Implementierungsaufwand. Eine interne DSL ist immer eine echte Untermenge einer generelleren Sprache.

Prominente Vertreter von internen DSLs sind:

  • Rake (das make für Ruby)
  • Xunit Frameworks
  • ein domänen-spezifisches UML2-Profil (Stereotypen, Stereotypeigenschaften und Constraints)
  • ein domänen-spezifisches XML-Schema (Elemente, Restriktionen)

Externe DSLs (external DSL)

Eine externe DSL ist eine von grundauf neu definierte Sprache. Sowohl die konkrete Syntax als auch die Semantik können hier frei definiert werden. Externe DSLs gelten daher als flexibler und ausdrucksstärker. War die Erstellung von externen DSLs in der Vergangenheit noch mit sehr viel Aufwand verbunden, so gibt es heute sehr gute Werkzeuge, die das Entwickeln von externen DSLs erheblich vereinfachen.

Prominente Beispiel für externe DSLs sind:

Nutzungsphasen

Eine DSL ist eine formale Sprache und kann daher maschinell unterstützt werden. Während bei internen DSLs die Definition, Nutzung und die Auswertung der DSL durch bestehende Werkzeuge unterstützt werden (Compiler, XML-Parser, XMI-Interpreter), müssen für externe DSL-Ansätze neue Werkzeuge erstellt werden.

Definition der Sprache

Zunächst einmal muss das Alphabet (domänenspezifische Schlüsselworte) der DSL festgelegt werden und die domänenspezifischen Satzbildungsregeln.

Erstellung von Sätzen

In der nächsten Phase erstellen Domänenexperten Sätze, die Alphabet und Satzbildungsregeln konform gehen, und die fachlichen Gegebenheiten in ihrem Problembereich spezifizieren.

Auswertung von Sätzen

Nachdem die Fachexperten ihre Spezifikationen erstellt haben, gilt es diese maschinell auszuwerten und automatisiert weiterzubearbeiten. Eine DSL kann mittels einer Domänentransformation in eine andere DSL überführt werden, um das fachliche Problem dort weiterzuverarbeiten. Irgendwann wird aber der Bereich der DSL verlassen und man überführt eine domänenspezifische Spezifikation in eine generische Spezifikation und kann diese dann mit Standardwerkzeugen in eine Problemlösung überführen.

Die domänenspezifische Spezifikation wird auf folgende Arten in eine andere DSL transformiert, oder in eine generische Spezifikation übersetzt:

Werkzeuge

Literatur

Siehe auch


Wikimedia Foundation.

Игры ⚽ Поможем написать реферат

Schlagen Sie auch in anderen Wörterbüchern nach:

  • problemorientierte Programmiersprache — problemorientierte Programmiersprache,   Programmiersprachen …   Universal-Lexikon

  • problemorientierte Programmiersprache — ⇡ Programmiersprache …   Lexikon der Economics

  • RPG (Programmiersprache) — RPG ist eine problemorientierte Programmiersprache für den kaufmännischen Bereich. Inhaltsverzeichnis 1 Zweck und Ursprung 2 RPG II, RPG III, RPG/400 3 RPG IV 3.1 Beispiele …   Deutsch Wikipedia

  • ILE RPG — RPG ist eine problemorientierte Programmiersprache für den kaufmännischen Bereich. Inhaltsverzeichnis 1 Zweck und Ursprung 2 RPG II , RPG III, RPG/400 3 RPG IV (ILE RPG) 3.1 Beispiele 4 Plattformen …   Deutsch Wikipedia

  • FORTRAN — Formula Translator * * * FỌRTRAN 〈n.; ; unz.; EDV〉 Programmiersprache für techn. u. mathemat. wissenschaftl. Aufgaben [engl. Kurzwort <formula translator „Formelübersetzer“] * * * FỌRTRAN   [Kunstwort von englisch formula translator],… …   Universal-Lexikon

  • CHILL — (Abkürzung für CCITT High Level Language) ist eine problemorientierte Programmiersprache, die hauptsächlich in der Kommunikationstechnik angewandt wird, zum Beispiel für rechnergesteuerte Vermittlungssysteme. CHILL gehört zur Algol 60 Familie,… …   Deutsch Wikipedia

  • Formelsprache — Fọr|mel|spra|che 〈f. 19〉 die in der Mathematik u. Chemie gebräuchliche Ausdrucksweise durch Formeln * * * Fọr|mel|spra|che, die: durch viele ↑ Formeln (1, 2) geprägte fachsprachliche Ausdrucksweise. * * * Formelsprache,   ursprünglich nur… …   Universal-Lexikon

  • CHILL —   [tʃɪl, Abkürzung für englisch CCITT high level language], Informatik: vom CCITT ausgearbeitete und empfohlene problemorientierte Programmiersprache für Kommunikationssysteme, besonders zur Formulierung von Steuerungsaufgaben bei Vermittl …   Universal-Lexikon

  • PEARL — [pə:l] das; Kurzw. aus engl. process and experiment automation realtime language> problemorientierte Programmiersprache, bes. zur Lösung von Echtzeitaufgaben (EDV) …   Das große Fremdwörterbuch

  • Cobol — Paradigmen: Zunächst rein imperativ, später erweitert um Elemente der strukturierten, prozeduralen und heutzutage sogar objektorientierten Programmierung Erscheinungsjahr: 1959 Entwickler: Grace Hopper, William Selden, Gertrude Tierney, Howar …   Deutsch Wikipedia

Share the article and excerpts

Direct link
Do a right-click on the link above
and select “Copy Link”