Dieser Artikel wurde maschinell übersetzt. Wenn Sie die englische Version des Artikels anzeigen möchten, aktivieren Sie das Kontrollkästchen Englisch. Sie können den englischen Text auch in einem Popupfenster anzeigen, indem Sie den Mauszeiger über den Text bewegen.
Übersetzung
Englisch

ValueType-Klasse

 

Veröffentlicht: Oktober 2016

Stellt die Basisklasse für Werttypen bereit.

Namespace:   System
Assembly:  mscorlib (in mscorlib.dll)

System.Object
  System.ValueType
    System.Enum

[SerializableAttribute]
[ComVisibleAttribute(true)]
public abstract class ValueType

NameBeschreibung
System_CAPS_protmethodValueType()

Initialisiert eine neue Instanz der ValueType-Klasse.

NameBeschreibung
System_CAPS_pubmethodEquals(Object)

Gibt an, ob diese Instanz und ein angegebenes Objekt gleich sind.(Überschreibt Object.Equals(Object).)

System_CAPS_protmethodFinalize()

Gibt einem Objekt Gelegenheit, Ressourcen freizugeben und andere Bereinigungen durchzuführen, bevor es von der Garbage Collection freigegeben wird. (Geerbt von „Object“.)

System_CAPS_pubmethodGetHashCode()

Gibt den Hashcode für diese Instanz zurück.(Überschreibt Object.GetHashCode().)

System_CAPS_pubmethodGetType()

Ruft den Type der aktuellen Instanz ab.(Geerbt von „Object“.)

System_CAPS_protmethodMemberwiseClone()

Erstellt eine flache Kopie des aktuellen Object.(Geerbt von „Object“.)

System_CAPS_pubmethodToString()

Gibt den voll qualifizierten Typnamen dieser Instanz zurück.(Überschreibt Object.ToString().)

ValueType überschreibt die virtuelle Methoden von Object mit angemessener Implementierungen für Werttypen. Siehe auch Enum, erbt von ValueType.

Datentypen werden in Werttypen und Verweistypen unterteilt. Werttypen werden entweder Stapeln oder Inline in einer Struktur zugeordnet werden. Verweistypen werden Heaps zugewiesen. Verweis- und Werttypen werden von der letztendlichen Basisklasse abgeleitet Object. In Fällen, in denen er für einen Werttyp wie ein Objekt Verhalten erforderlich ist, werden ein Wrapper, der Werttyp ein Reference-Objekt auf dem Heap reserviert ist und der Werttyp Wert in diese kopiert wird. Der Wrapper wird markiert, sodass das System erkennt, dass es sich um einen Werttyp enthält. Dieser Prozess wird als Boxing bezeichnet, und der umgekehrte Vorgang wird als unboxing bezeichnet. Boxing und unboxing können beliebigen Typs als Objekt behandelt werden.

Obwohl ValueType ist die implizite Basisklasse für Werttypen können nicht Sie erstellen eine Klasse, die von erbt ValueType direkt. Geben Sie ein Schlüsselwort oder das erstellen stattdessen einzelne Compiler (z. B. struct in c# und Structure...End Structure in Visual Basic) zum unterstützen der Erstellung von Werttypen.

Dient als Basisklasse für Werttypen in .NET Framework zwar die ValueType Struktur wird im Allgemeinen nicht direkt im Code verwendet. Allerdings können sie als Parameter in Methodenaufrufen mögliche Argumente auf Werttypen statt alle Objekte zu beschränken, oder eine Methode, eine Anzahl von verschiedenen Werttypen verarbeiten zuzulassen, verwendet werden. Im folgende Beispiel wird veranschaulicht, wie ValueType verhindert, dass Verweistypen an Methoden übergeben werden. Definiert eine Klasse namens Utility enthält vier Methoden: IsNumeric, der angibt, ob das Argument eine Zahl ist; IsInteger, die angibt, ob das Argument eine ganze Zahl, IsFloat, die angibt, ob das Argument eine Gleitkommazahl; und Compare, gibt die Beziehung zwischen zwei numerische Werte an. In jedem Fall sind die Methodenparameter des Typs ValueType, Verweistypen gehindert werden, an die Methoden übergeben werden.

using System;
using System.Numerics;


public class Utility
{
   public enum NumericRelationship {
      GreaterThan = 1, 
      EqualTo = 0,
      LessThan = -1
   };

   public static NumericRelationship Compare(ValueType value1, ValueType value2)
   {
      if (! IsNumeric(value1)) 
         throw new ArgumentException("value1 is not a number.");
      else if (! IsNumeric(value2))
         throw new ArgumentException("value2 is not a number.");

      // Use BigInteger as common integral type
      if (IsInteger(value1) && IsInteger(value2)) {
         BigInteger bigint1 = (BigInteger) value1;
         BigInteger bigint2 = (BigInteger) value2;
         return (NumericRelationship) BigInteger.Compare(bigint1, bigint2);
      }
      // At least one value is floating point; use Double.
      else {
         Double dbl1 = 0;
         Double dbl2 = 0;
         try {
            dbl1 = Convert.ToDouble(value1);
         }
         catch (OverflowException) {
            Console.WriteLine("value1 is outside the range of a Double.");
         }
         try {
            dbl2 = Convert.ToDouble(value2);
         }
         catch (OverflowException) {
            Console.WriteLine("value2 is outside the range of a Double.");
         }
         return (NumericRelationship) dbl1.CompareTo(dbl2);
      }
   }

   public static bool IsInteger(ValueType value)
   {         
      return (value is SByte || value is Int16 || value is Int32 
              || value is Int64 || value is Byte || value is UInt16  
              || value is UInt32 || value is UInt64 
              || value is BigInteger); 
   }

   public static bool IsFloat(ValueType value) 
   {         
      return (value is float | value is double | value is Decimal);
   }

   public static bool IsNumeric(ValueType value)
   {
      return (value is Byte ||
              value is Int16 ||
              value is Int32 ||
              value is Int64 ||
              value is SByte ||
              value is UInt16 ||
              value is UInt32 ||
              value is UInt64 ||
              value is BigInteger ||
              value is Decimal ||
              value is Double ||
              value is Single);
   }
}

Das folgende Beispiel veranschaulicht Aufrufe der Methoden von der Utility Klasse.

public class Example
{
   public static void Main()
   {
      Console.WriteLine(Utility.IsNumeric(12));
      Console.WriteLine(Utility.IsNumeric(true));
      Console.WriteLine(Utility.IsNumeric('c'));
      Console.WriteLine(Utility.IsNumeric(new DateTime(2012, 1, 1)));
      Console.WriteLine(Utility.IsInteger(12.2));
      Console.WriteLine(Utility.IsInteger(123456789));
      Console.WriteLine(Utility.IsFloat(true));
      Console.WriteLine(Utility.IsFloat(12.2));
      Console.WriteLine(Utility.IsFloat(12));
      Console.WriteLine("{0} {1} {2}", 12.1, Utility.Compare(12.1, 12), 12);
   }
}
// The example displays the following output:
//       True
//       False
//       False
//       False
//       False
//       True
//       False
//       True
//       False
//       12.1 GreaterThan 12

Universelle Windows-Plattform
Verfügbar seit 8
.NET Framework
Verfügbar seit 1.1
Portierbare Klassenbibliothek
Unterstützt in: portierbare .NET-Plattformen
Silverlight
Verfügbar seit 2.0
Windows Phone Silverlight
Verfügbar seit 7.0
Windows Phone
Verfügbar seit 8.1

Alle öffentlichen statischen Member ( Shared in Visual Basic) dieses Typs sind threadsicher. Die Threadsicherheit für Instanzmember ist nicht garantiert.

Zurück zum Anfang
Anzeigen: