„Digraph (Informatik)“ – Versionsunterschied
[gesichtete Version] | [gesichtete Version] |
K form |
tk k |
||
Zeile 18: | Zeile 18: | ||
== Digraphen in [[Varianten der Programmiersprache C#C95|C]] und [[C++]] == |
== Digraphen in [[Varianten der Programmiersprache C#C95|C]] und [[C++]] == |
||
{| class="wikitable" |
|||
|- class="hintergrundfarbe6" |
|- class="hintergrundfarbe6" |
||
! Digraph !! ersetztes Zeichen !! Verwendung |
! Digraph !! ersetztes Zeichen !! Verwendung |
||
Zeile 31: | Zeile 31: | ||
|- |
|- |
||
| <code>%:</code> || <code>#</code> || Kennzeichen für Präprozessoranweisungen |
| <code>%:</code> || <code>#</code> || Kennzeichen für Präprozessoranweisungen |
||
|}<ref name="BSI" /><ref>{{Internetquelle | |
|}<ref name="BSI" /><ref>{{Internetquelle |url=http://www.open-std.org/jtc1/sc22/wg14/www/C99RationaleV5.10.pdf |titel=Rationale für C99, Revision 5.10 |format=PDF; 898 kB |zugriff=2010-10-17 |sprache=en |kommentar=Kapitel 5.2.1.1}}</ref> |
||
Die Verwendung von Digraphen (wie auch von [[Trigraph]]en) gilt heutzutage als überholt, da inzwischen auf nahezu allen Plattformen der komplette [[American Standard Code for Information Interchange|ASCII]]-Zeichensatz unterstützt wird. |
Die Verwendung von Digraphen (wie auch von [[Trigraph]]en) gilt heutzutage als überholt, da inzwischen auf nahezu allen Plattformen der komplette [[American Standard Code for Information Interchange|ASCII]]-Zeichensatz unterstützt wird. |
||
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> |
||
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.<ref>http://en.cppreference.com/w/cpp/language/operator_alternative</ref> |
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.<ref>[http://en.cppreference.com/w/cpp/language/operator_alternative en.cppreference.com]</ref> |
||
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: |
||
Zeile 64: | Zeile 64: | ||
<ref name="BSI"> |
<ref name="BSI"> |
||
{{Literatur |
{{Literatur |
||
⚫ | |||
⚫ | |||
⚫ | |||
|Verlag=John Wiley & Sons |
|Verlag=John Wiley & Sons |
||
⚫ | |||
|ISBN=0-470-84573-2 |
|ISBN=0-470-84573-2 |
||
|Kapitel=6.4.6 |
|Kapitel=6.4.6 |
||
⚫ | |||
⚫ | |||
</ref> |
</ref> |
||
</references> |
</references> |
Version vom 24. Februar 2017, 14:42 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).
- ↑ en.cppreference.com