Zeigertypen (C#-Programmierhandbuch)

Aktualisiert: November 2007

In einem unsicheren Kontext kann ein Typ sowohl ein Zeigertyp als auch ein Werttyp oder Verweistyp sein. Eine Zeigertypdeklaration erfolgt in einer der folgenden Formen:

type* identifier;
void* identifier; //allowed but not recommended

Die folgenden Typen können Zeigertypen sein:

Zeigertypen erben nicht von object, und es ist keine Konvertierung zwischen Zeigertypen und object möglich. Weiterhin unterstützen Boxing und Unboxing keine Zeiger. Es ist jedoch möglich, Konvertierungen zwischen verschiedenen Zeigertypen sowie zwischen Zeigertypen und ganzzahligen Typen durchzuführen.

Wenn Sie mehrere Zeiger innerhalb ein- und derselben Deklaration deklarieren, wird das * nicht als Präfix für jeden Zeigernamen, sondern nur einmal mit dem zugrunde liegenden Typ notiert. Beispiel:

int* p1, p2, p3;   // Ok
int *p1, *p2, *p3;   // Invalid in C#

Ein Zeiger kann nicht auf einen Verweis oder eine Struktur verweisen, die Verweise enthält, da ein Objektverweis auch dann nicht in die Garbage Collection aufgenommen werden kann, wenn ein Zeiger darauf verweist. In der Garbage Collection wird nicht nachgehalten, ob von einem der Zeigertypen auf ein Objekt verwiesen wird.

Der Wert der Zeigervariablen vom Typ myType* ist die Adresse einer Variablen vom Typ myType. Im Folgenden finden Sie Beispiele für Zeigertypdeklarationen:

Beispiel

Beschreibung

int* p

p ist ein Zeiger auf einen ganzzahligen Wert.

int** p

p ist ein Zeiger auf einen Zeiger auf einen ganzzahligen Wert.

int*[] p

p ist ein eindimensionales Array von Zeigern auf ganzzahlige Werte.

char* p

p ist ein Zeiger auf eine char-Variable.

void* p

p ist ein Zeiger auf einen unbekannten Typ.

Sie können den Zeigerdereferenzierungsoperator * verwenden, um auf den Inhalt an der Speicherstelle zuzugreifen, auf die die Zeigervariable zeigt. Betrachten Sie beispielsweise die folgende Deklaration:

int* myVariable;

Der Ausdruck *myVariable kennzeichnet die int-Variable, die sich an der in myVariable enthaltenen Adresse befindet.

Der Dereferenzierungsoperator kann nicht auf Zeiger vom Typ void* angewendet werden. Sie können jedoch eine Umwandlung verwenden, um einen void-Zeiger zu einem anderen Zeigertyp und umgekehrt zu konvertieren.

Ein Zeiger kann den Wert null annehmen. Die Anwendung des Dereferenzierungsoperators auf einen NULL-Zeiger führt zu einem in der Implementierung definierten Verhalten.

Beachten Sie, dass die Übergabe von Zeigern zwischen Methoden zu nicht definiertem Verhalten führen kann. Dies betrifft zum Beispiel die Rückgabe eines Zeigers an eine lokale Variable als Out-Parameter, Ref-Parameter oder als Funktionsergebnis. Wenn der Zeiger in einem fixed-Block festgelegt wurde, ist die Variable, auf die der Zeiger verweist, möglicherweise nicht fixiert.

In der folgenden Tabelle werden die Operatoren und Anweisungen aufgelistet, die in einem unsicheren Kontext auf Zeiger angewendet werden können.

Operator/Anweisung

Verwendung

*

Führt eine Zeigerdereferenzierung aus.

->

Greift über einen Zeiger auf einen Member einer Struktur zu.

[]

Indiziert einen Zeiger.

&

Ruft die Adresse einer Variablen ab.

++ und --

Inkrementiert und dekrementiert Zeiger.

+ und -

Führt Zeigerarithmetik aus.

==, !=, <, >, <= und >=

Vergleicht Zeiger.

stackalloc

Weist dem Stapel Speicher zu.

fixed-Anweisung

Korrigiert eine Variable vorübergehend, damit die Adresse gefunden werden kann.

C#-Programmiersprachenspezifikation

Weitere Informationen finden Sie im folgenden Abschnitt in der C#-Programmiersprachenspezifikation:

  • 18 Unsicherer Code

Siehe auch

Konzepte

C#-Programmierhandbuch

Referenz

Unsicherer Code und Zeiger (C#-Programmierhandbuch)

Zeigerkonvertierungen (C#-Programmierhandbuch)

Zeigerausdrücke (C#-Programmierhandbuch)

unsafe (C#-Referenz)

fixed-Anweisung (C#-Referenz)

stackalloc (C#-Referenz)

Boxing und Unboxing (C#-Programmierhandbuch)

Weitere Ressourcen

Typen (C#-Referenz)