Auf Englisch lesen

Freigeben über


ValueType Klasse

Definition

Stellt die Basisklasse für Werttypen bereit.

C#
public abstract class ValueType
C#
[System.Serializable]
public abstract class ValueType
C#
[System.Serializable]
[System.Runtime.InteropServices.ComVisible(true)]
public abstract class ValueType
Vererbung
ValueType
Abgeleitet
Attribute

Hinweise

ValueType überschreibt die virtuellen Methoden aus Object mit geeigneteren Implementierungen für Werttypen. Siehe auch Enum, die von ValueTypeerbt.

Datentypen werden in Werttypen und Verweistypen getrennt. Werttypen sind entweder stack-zugeordnet oder inline in einer Struktur zugeordnet. Referenztypen sind heap-zugeordnet. Sowohl Bezugs- als auch Werttypen werden von der ultimativen Basisklasse Objectabgeleitet. In Fällen, in denen es erforderlich ist, dass sich ein Werttyp wie ein Objekt verhält, wird ein Wrapper, der den Werttyp so aussieht, als ob ein Referenzobjekt für den Heap zugewiesen wird, und der Werttyp wird in ihn kopiert. Der Wrapper ist markiert, damit das System weiß, dass er einen Werttyp enthält. Dieser Prozess wird als Boxen bezeichnet, und der Umgekehrte Prozess wird als Unboxing bezeichnet. Durch Boxen und Entboxen kann jeder Typ als Objekt behandelt werden.

Obwohl ValueType die implizite Basisklasse für Werttypen ist, können Sie keine Klasse erstellen, die direkt von ValueType erbt. Stattdessen stellen einzelne Compiler ein Sprachstichwort oder -konstrukt (z. B. struct in C# und Structure...End Structure in Visual Basic) bereit, um die Erstellung von Werttypen zu unterstützen.

Abgesehen von der Verwendung als Basisklasse für Werttypen in .NET Framework wird die ValueType Struktur im Allgemeinen nicht direkt im Code verwendet. Es kann jedoch als Parameter in Methodenaufrufen verwendet werden, um mögliche Argumente auf Werttypen anstelle aller Objekte einzuschränken oder eine Methode zum Behandeln einer Reihe unterschiedlicher Werttypen zuzulassen. Im folgenden Beispiel wird veranschaulicht, wie ValueType verhindert, dass Verweistypen an Methoden übergeben werden. Es definiert eine Klasse mit dem Namen Utility, die vier Methoden enthält: IsNumeric, die angibt, ob das Argument eine Zahl ist; IsInteger, der angibt, ob es sich bei dem Argument um eine ganze Zahl handelt; IsFloat, das angibt, ob es sich bei dem Argument um eine Gleitkommazahl handelt; und Compare, was die Beziehung zwischen zwei numerischen Werten angibt. In jedem Fall sind die Methodenparameter vom Typ ValueType, und Verweistypen werden daran gehindert, an die Methoden übergeben zu werden.

C#
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);
   }
}

Im folgenden Beispiel werden Aufrufe der Methoden der Utility Klasse veranschaulicht.

C#
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

Konstruktoren

ValueType()

Initialisiert eine neue Instanz der ValueType Klasse.

Methoden

Equals(Object)

Gibt an, ob diese Instanz und ein angegebenes Objekt gleich sind.

GetHashCode()

Gibt den Hashcode für diese Instanz zurück.

GetType()

Ruft die Type der aktuellen Instanz ab.

(Geerbt von Object)
MemberwiseClone()

Erstellt eine flache Kopie der aktuellen Object.

(Geerbt von Object)
ToString()

Gibt den vollqualifizierten Typnamen dieser Instanz zurück.

Gilt für:

Produkt Versionen
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 2.0, 2.1
UWP 10.0

Weitere Informationen