„Digraph (Informatik)“ – Versionsunterschied
[gesichtete Version] | [gesichtete Version] |
Markierungen: Mobile Bearbeitung Mobile Web-Bearbeitung |
K form |
||
Zeile 15: | Zeile 15: | ||
|} |
|} |
||
Bei vielen Compilern wird |
Bei vielen Compilern wird <code>(*</code> und <code>*)</code> jedoch nicht als Digraph interpretiert, sondern sie kennzeichnen einen eigenen Kommentarblock-Stil. Ein Kommentar, der durch <code>(*</code> begonnen wird, kann somit nicht mit <code>}</code> beendet werden und umgekehrt. |
||
== Digraphen in [[Varianten der Programmiersprache C#C95|C]] und [[C++]] == |
== Digraphen in [[Varianten der Programmiersprache C#C95|C]] und [[C++]] == |
||
Zeile 39: | Zeile 39: | ||
Beispiel: |
Beispiel: |
||
<syntaxhighlight lang="cpp"> |
<syntaxhighlight lang="cpp"> |
||
std::vector<::std::size_t> v; |
|||
</syntaxhighlight> |
</syntaxhighlight> |
||
Dies lässt sich lösen, indem ein [[Leerzeichen]] eingefügt wird: |
Dies lässt sich lösen, indem ein [[Leerzeichen]] eingefügt wird: |
||
<syntaxhighlight lang="cpp"> |
<syntaxhighlight lang="cpp"> |
||
std::vector<␣::std::size_t> v; |
|||
</syntaxhighlight> |
</syntaxhighlight> |
||
Zeile 51: | Zeile 51: | ||
Mit dem Makro |
Mit dem Makro |
||
<syntaxhighlight lang="cpp"> |
<syntaxhighlight lang="cpp"> |
||
#define PROC_CAT(l, r) l ## r |
|||
</syntaxhighlight> |
</syntaxhighlight> |
||
lassen sich alle Digraphen zusammenfügen zu den entsprechenden Zeichen, nur die Raute nicht: |
lassen sich alle Digraphen zusammenfügen zu den entsprechenden Zeichen, nur die Raute nicht: |
Version vom 8. Januar 2017, 22:57 Uhr
Als Digraph bezeichnet man in der Informatik eine Kombination aus zwei Zeichen, welche als Ersatz für ein einzelnes Zeichen stehen, welches nicht im verwendeten Zeichensatz zur Verfügung steht. Verschiedene Programmiersprachen machen hiervon Gebrauch.
Digraphen in Pascal
Digraph | ersetztes Zeichen | Verwendung |
---|---|---|
(* |
{ |
Beginn eines Kommentars |
*) |
} |
Ende eines Kommentars |
(. |
[ |
Öffnende Klammer für Feldindex |
.) |
] |
Schließende Klammer für Feldindex |
Bei vielen Compilern wird (*
und *)
jedoch nicht als Digraph interpretiert, sondern sie kennzeichnen einen eigenen Kommentarblock-Stil. Ein Kommentar, der durch (*
begonnen wird, kann somit nicht mit }
beendet werden und umgekehrt.
Digraph ersetztes Zeichen Verwendung <:
[
Öffnende Klammer für Feldindex :>
]
Schließende Klammer für Feldindex <%
{
Öffnende Blockklammer %>
}
Schließende Blockklammer %:
#
Kennzeichen für Präprozessoranweisungen
Die Verwendung von Digraphen (wie auch von Trigraphen) gilt heutzutage als überholt, da inzwischen auf nahezu allen Plattformen der komplette ASCII-Zeichensatz unterstützt wird.
Da die Digraphen jedoch noch immer in der Sprache definiert sind, kann dies zu subtilen und bisweilen schwer zu findenden Fehlern führen, welche jedoch von aktuellen Compilern angezeigt werden.
Beispiel:
std::vector<::std::size_t> v;
Dies lässt sich lösen, indem ein Leerzeichen eingefügt wird:
std::vector<␣::std::size_t> v;
Seit C++11 ist dieses Leerzeichen nicht mehr nötig. Die Syntaxdefinition wurde entsprechend angepasst, dass o.g. Code auch ohne Leerzeichen korrekt geparst wird.[3]
Mit dem Makro
#define PROC_CAT(l, r) l ## r
lassen sich alle Digraphen zusammenfügen zu den entsprechenden Zeichen, nur die Raute nicht:
PROC_CAT(<, :) //Wird zu "{"
PROC_CAT(new int <, :10:>) //Wird zu new int [10]
PROC_CAT(%, :) define NOT_POSSIBLE //Erzeugt Fehler "stray '%:' in program
Einzelnachweise
- ↑ British Standards Institute (Hrsg.): The C Standard - Incorporating TC1 - BS ISO/IEC 9899:1999. John Wiley & Sons, 2003, ISBN 0-470-84573-2, 6.4.6.
- ↑ Rationale für C99, Revision 5.10. (PDF; 898 kB) Abgerufen am 17. Oktober 2010 (englisch, Kapitel 5.2.1.1).
- ↑ http://en.cppreference.com/w/cpp/language/operator_alternative