Literal

aus Wikipedia, der freien Enzyklopädie
(Weitergeleitet von Literale)
Zur Navigation springen Zur Suche springen

Ein Literal ist ein spezieller Bestandteil einer formalen Sprache.

Literale in Programmiersprachen

[Bearbeiten | Quelltext bearbeiten]

Rolle von Literalen in Programmiersprachen

[Bearbeiten | Quelltext bearbeiten]

Als Literal (lateinisch litteraBuchstabe‘) bezeichnet man in Programmiersprachen eine Zeichenfolge, die zur direkten Darstellung der Werte von Basistypen (z. B. Ganzzahlen, Gleitkommazahlen, Zeichenketten, Funktionen) definiert bzw. zulässig ist.

Man unterscheidet logische (wahr, nicht wahr), numerische und Zeichenliterale. Je nach Programmiersprache gibt es weitere und detailliertere Kategorisierungen für Literale. Damit Literale vom Compiler identifiziert werden können, müssen sie bestimmten syntaktischen Regeln genügen, z. B. (sprachenabhängig und in bestimmten Fällen) in Anführungszeichen eingeschlossen sein.

Literale als Teil von Befehlen werden auch als literale Konstanten oder nicht benannte Konstanten bezeichnet, da sowohl Literale als auch Konstanten zur Laufzeit des Programms unveränderlich sind. Literale dürfen in Zuweisungsoperatoren nur als Sende-Ausdruck (i. d. R. rechtsseitig; 'Zeilen = 60'), als Argument einer Funktion oder als der Wert einer Konstante codiert werden.

In der funktionalen Programmierung können auch Funktionen als Literale geschrieben werden. Diese werden als anonyme Funktionen oder Lambda-Funktionen bezeichnet.

Ähnlich dem Literalbegriff kennen manche Programmiersprachen sog. „figurative Konstanten“. Dies sind (z. B. in Cobol) gem.[1] „Cobol-Worte [in unterschiedlichen Schreibweisen, z. B. in Pluralform] für die vom Compiler bestimmte Werte erzeugt werden“: Zero, Space, High-Value und Low-Value, Quote und 'ALL Literal'.

Als Aspekt des Programmierstils wird zum Teil empfohlen, im Befehlsteil des Programmcodes möglichst keine Literale, sondern ersatzweise Konstanten zu verwenden, die im Quelltext beliebig oft angesprochen werden können – anstatt immer das gleiche Literal zu verwenden. Diese Vorschrift soll zu höherer Transparenz und Wartungsfreundlichkeit führen.

In JavaScript können auch strukturierte Daten wie Arrays und Objekte als Literale geschrieben werden, in Tcl dagegen Listen und Dictionaries.

Beispiele für Literale

[Bearbeiten | Quelltext bearbeiten]
Wahrheitswerte: true, false (in vielen Sprachen als reservierte Wörter)
Ganzzahlen: 1200, +1200, −12 (nur Ziffern und + oder −)
Gleitkommazahlen: 12.34, −12e34, 12.e-34 (Ziffern, Vorzeichen, Punkt, e)
Einzelnes Zeichen: 'a' (beliebiges einzelnes Zeichen in Anführungszeichen)
Zeichenketten: "ABCD(12)$ ist eine Zeichenkette" (mehrere Zeichen in doppelten Anführungszeichen)
JSON:
{"mitarbeiter":[
  {"vName":"Jonas", "fName":"Dörfner"},
  {"vName":"Anna Lena", "fName":"Schmitz"},
  {"vName":"Peter", "fName":"Meier"}
  ]
}
(ein Objekt, das ein Array mit mehreren Objekten enthält)
Dictionary in Tcl:
{mitarbeiter {
  {vName Jonas fName Dörfner}
  {vName {Anna Lena} fName Schmitz}
  {vName Peter fName Meier}
}
(inhaltlich identisch mit dem JSON-Beispiel darüber, statt des Arrays ist es in Tcl eine Liste mit 3 Elementen)
Liste in Tcl:
{{rote Grütze} gelb {grüne Soße}}
(drei Listenelemente)
S-Expressions (symbolische Ausdrücke) in Lisp:
(quote
 (mitarbeiter
  (:vname "Jonas"     :fname "Dörfner")
  (:vname "Anna Lena" :fname "Schmitz")
  (:vname "Peter"     :fname "Meier")))
verschachtelte Listen mit Symbolen und Strings, quotiert als Literal
Funktionsliteral in Haskell:
(\x -> 2*x)
verdoppelt eine Zahl

Literale in der mathematischen Logik

[Bearbeiten | Quelltext bearbeiten]

In der mathematischen Logik ist ein Literal eine atomare Aussage (Atom) oder die Negation einer atomaren Aussage. Man hat daher positive Literale und negative Literale. Eine disjunktive Verknüpfung von Literalen bezeichnet man als Disjunktionsterm oder als Klausel. Eine rein konjunktive Verknüpfung von Literalen bezeichnet man als Konjunktionsterm oder als Monom.

Wiktionary: Literal – Bedeutungserklärungen, Wortherkunft, Synonyme, Übersetzungen

Einzelnachweise

[Bearbeiten | Quelltext bearbeiten]
  1. Allgemeine Cobol-Programmstruktur (PDF@1@2Vorlage:Toter Link/www.mitp.de (Seite nicht mehr abrufbar, festgestellt im April 2019. Suche in Webarchiven)  Info: Der Link wurde automatisch als defekt markiert. Bitte prüfe den Link gemäß Anleitung und entferne dann diesen Hinweis.)