Leggi in inglese

Condividi tramite


ValueType Classe

Definizione

Fornisce la classe base per i tipi valore.

C#
public abstract class ValueType
C#
[System.Serializable]
public abstract class ValueType
C#
[System.Serializable]
[System.Runtime.InteropServices.ComVisible(true)]
public abstract class ValueType
Ereditarietà
ValueType
Derivato
Attributi

Commenti

ValueType esegue l'override dei metodi virtuali da Object con implementazioni più appropriate per i tipi valore. Vedere anche Enum, che eredita da ValueType.

I tipi di dati sono separati in tipi valore e tipi riferimento. I tipi valore sono allocati nello stack o inline allocati in una struttura. I tipi di riferimento sono allocati dall'heap. Sia i tipi reference che value sono derivati dalla classe base finale Object. Nei casi in cui è necessario che un tipo di valore si comporti come un oggetto , un wrapper che rende il tipo di valore simile a un oggetto riferimento viene allocato nell'heap e il valore del tipo di valore viene copiato in esso. Il wrapper è contrassegnato in modo che il sistema sappia che contiene un tipo di valore. Questo processo è noto come boxing e il processo inverso è noto come unboxing. Boxing e unboxing consentono a qualsiasi tipo di essere considerato come oggetto .

Sebbene ValueType sia la classe base implicita per i tipi valore, non è possibile creare direttamente una classe che eredita da ValueType. I singoli compilatori forniscono invece una parola chiave o un costrutto del linguaggio ( ad esempio struct in C# e Structure...End Structure in Visual Basic) per supportare la creazione di tipi valore.

Oltre a fungere da classe base per i tipi valore in .NET Framework, la struttura ValueType in genere non viene usata direttamente nel codice. Tuttavia, può essere usato come parametro nelle chiamate al metodo per limitare i possibili argomenti ai tipi valore anziché a tutti gli oggetti oppure per consentire a un metodo di gestire un numero di tipi valore diversi. Nell'esempio seguente viene illustrato come ValueType impedisce che i tipi di riferimento vengano passati ai metodi. Definisce una classe denominata Utility che contiene quattro metodi: IsNumeric, che indica se il relativo argomento è un numero; IsInteger, che indica se il relativo argomento è un numero intero; IsFloat, che indica se il relativo argomento è un numero a virgola mobile; e Compare, che indica la relazione tra due valori numerici. In ogni caso, i parametri del metodo sono di tipo ValueTypee i tipi riferimento non vengono passati ai metodi .

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

Nell'esempio seguente vengono illustrate le chiamate ai metodi della classe Utility.

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

Costruttori

ValueType()

Inizializza una nuova istanza della classe ValueType.

Metodi

Equals(Object)

Indica se questa istanza e un oggetto specificato sono uguali.

GetHashCode()

Restituisce il codice hash per questa istanza.

GetType()

Ottiene il Type dell'istanza corrente.

(Ereditato da Object)
MemberwiseClone()

Crea una copia superficiale del Objectcorrente.

(Ereditato da Object)
ToString()

Restituisce il nome completo del tipo di questa istanza.

Si applica a

Prodotto Versioni
.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

Vedi anche