Convert.ToByte Metodo

Definizione

Converte un valore specificato in un intero senza segno a 8 bit.

Overload

ToByte(String)

Converte la rappresentazione di stringa specificata di un numero in un intero senza segno a 8 bit equivalente.

ToByte(UInt16)

Converte il valore dell'intero senza segno a 16 bit specificato in un intero senza segno a 8 bit equivalente.

ToByte(UInt32)

Converte il valore dell'intero senza segno a 32 bit specificato in un intero senza segno a 8 bit equivalente.

ToByte(String, Int32)

Converte la rappresentazione di stringa di un numero in una base specificata in un intero senza segno a 8 bit equivalente.

ToByte(Object, IFormatProvider)

Converte il valore dell'oggetto specificato in un intero senza segno a 8 bit utilizzando le informazioni di formattazione specifiche delle impostazioni cultura specificate.

ToByte(String, IFormatProvider)

Converte la rappresentazione di stringa specificata di un numero in un intero senza segno a 8 bit equivalente, utilizzando le informazioni di formattazione specifiche delle impostazioni cultura specificate.

ToByte(Single)

Converte il valore del numero a virgola mobile e precisione singola specificato in un intero senza segno a 8 bit equivalente.

ToByte(UInt64)

Converte il valore dell'intero senza segno a 64 bit specificato in un intero senza segno a 8 bit equivalente.

ToByte(SByte)

Converte il valore dell'intero con segno a 8 bit specificato in un intero senza segno a 8 bit equivalente.

ToByte(DateTime)

La chiamata a questo metodo genera sempre InvalidCastException.

ToByte(Int64)

Converte il valore dell'intero con segno a 64 bit specificato in un intero senza segno a 8 bit equivalente.

ToByte(Byte)

Restituisce l'intero senza segno a 8 bit specificato; non viene eseguita alcuna conversione effettiva.

ToByte(Char)

Converte il valore del carattere Unicode specificato nell'intero senza segno a 8 bit equivalente.

ToByte(Decimal)

Converte il valore del numero decimale specificato in un intero senza segno a 8 bit equivalente.

ToByte(Boolean)

Converte il valore booleano specificato nell'intero senza segno a 8 bit equivalente.

ToByte(Int16)

Converte il valore dell'intero con segno a 16 bit specificato in un intero senza segno a 8 bit equivalente.

ToByte(Int32)

Converte il valore dell'intero con segno a 32 bit specificato in un intero senza segno a 8 bit equivalente.

ToByte(Double)

Converte il valore del numero a virgola mobile e precisione doppia specificato in un intero senza segno a 8 bit equivalente.

ToByte(Object)

Converte il valore dell'oggetto specificato in un intero senza segno a 8 bit.

ToByte(String)

Origine:
Convert.cs
Origine:
Convert.cs
Origine:
Convert.cs

Converte la rappresentazione di stringa specificata di un numero in un intero senza segno a 8 bit equivalente.

public static byte ToByte (string value);
public static byte ToByte (string? value);

Parametri

value
String

Stringa contenente il numero da convertire.

Restituisce

Intero senza segno a 8 bit equivalente a valueo zero se value è null.

Eccezioni

value non è costituito da un segno facoltativo seguito da una sequenza di cifre (da 0 a 9).

value rappresenta un numero minore di Byte.MinValue o maggiore di Byte.MaxValue.

Esempio

L'esempio seguente definisce una matrice di stringhe e tenta di convertire ogni stringa in un Byte. Si noti che mentre una stringa di null analizza su zero, String.Empty genera un'eccezione FormatException. Si noti anche che durante l'analisi degli spazi iniziali e finali, i simboli di formattazione, ad esempio simboli di valuta, separatori di gruppo o separatori decimali, non lo sono.

using System;

public class Example
{
   public static void Main()
   {
      String[] values = { null, "", "0xC9", "C9", "101", "16.3",
                          "$12", "$12.01", "-4", "1,032", "255",
                          "   16  " };
      foreach (var value in values) {
         try {
            byte number = Convert.ToByte(value);
            Console.WriteLine("'{0}' --> {1}",
                              value == null ? "<null>" : value, number);
         }
         catch (FormatException) {
            Console.WriteLine("Bad Format: '{0}'",
                              value == null ? "<null>" : value);
         }
         catch (OverflowException) {
            Console.WriteLine("OverflowException: '{0}'", value);
         }
      }
   }
}
// The example displays the following output:
//     '<null>' --> 0
//     Bad Format: ''
//     Bad Format: '0xC9'
//     Bad Format: 'C9'
//     '101' --> 101
//     Bad Format: '16.3'
//     Bad Format: '$12'
//     Bad Format: '$12.01'
//     OverflowException: '-4'
//     Bad Format: '1,032'
//     '255' --> 255
//     '   16  ' --> 16

Commenti

L'uso del metodo ToByte(String) equivale al passaggio di value al metodo Byte.Parse(String). value viene interpretato usando le convenzioni di formattazione delle impostazioni cultura correnti.

Se si preferisce non gestire un'eccezione se la conversione non riesce, è possibile chiamare invece il metodo Byte.TryParse. Restituisce un valore Boolean che indica se la conversione ha avuto esito positivo o negativo.

Vedi anche

Si applica a

ToByte(UInt16)

Origine:
Convert.cs
Origine:
Convert.cs
Origine:
Convert.cs

Importante

Questa API non è conforme a CLS.

Converte il valore dell'intero senza segno a 16 bit specificato in un intero senza segno a 8 bit equivalente.

[System.CLSCompliant(false)]
public static byte ToByte (ushort value);

Parametri

value
UInt16

Intero senza segno a 16 bit da convertire.

Restituisce

Intero senza segno a 8 bit equivalente a value.

Attributi

Eccezioni

value è maggiore di Byte.MaxValue.

Esempio

Nell'esempio seguente viene convertita una matrice di interi senza segno a 16 bit in valori Byte.

ushort[] numbers = { UInt16.MinValue, 121, 340, UInt16.MaxValue };
byte result;
foreach (ushort number in numbers)
{
   try {
      result = Convert.ToByte(number);
      Console.WriteLine("Converted the {0} value {1} to the {2} value {3}.",
                        number.GetType().Name, number,
                        result.GetType().Name, result);
   }
   catch (OverflowException) {
      Console.WriteLine("The {0} value {1} is outside the range of the Byte type.",
                        number.GetType().Name, number);
   }
}
// The example displays the following output:
//       Converted the UInt16 value 0 to the Byte value 0.
//       Converted the UInt16 value 121 to the Byte value 121.
//       The UInt16 value 340 is outside the range of the Byte type.
//       The UInt16 value 65535 is outside the range of the Byte type.

Si applica a

ToByte(UInt32)

Origine:
Convert.cs
Origine:
Convert.cs
Origine:
Convert.cs

Importante

Questa API non è conforme a CLS.

Converte il valore dell'intero senza segno a 32 bit specificato in un intero senza segno a 8 bit equivalente.

[System.CLSCompliant(false)]
public static byte ToByte (uint value);

Parametri

value
UInt32

Intero senza segno a 32 bit da convertire.

Restituisce

Intero senza segno a 8 bit equivalente a value.

Attributi

Eccezioni

value è maggiore di Byte.MaxValue.

Esempio

Nell'esempio seguente viene convertita una matrice di interi senza segno in valori Byte.

uint[] numbers = { UInt32.MinValue, 121, 340, UInt32.MaxValue };
byte result;
foreach (uint number in numbers)
{
   try {
      result = Convert.ToByte(number);
      Console.WriteLine("Converted the {0} value {1} to the {2} value {3}.",
                        number.GetType().Name, number,
                        result.GetType().Name, result);
   }
   catch (OverflowException) {
      Console.WriteLine("The {0} value {1} is outside the range of the Byte type.",
                        number.GetType().Name, number);
   }
}
// The example displays the following output:
//       Converted the UInt32 value 0 to the Byte value 0.
//       Converted the UInt32 value 121 to the Byte value 121.
//       The UInt32 value 340 is outside the range of the Byte type.
//       The UInt32 value 4294967295 is outside the range of the Byte type.

Si applica a

ToByte(String, Int32)

Origine:
Convert.cs
Origine:
Convert.cs
Origine:
Convert.cs

Converte la rappresentazione di stringa di un numero in una base specificata in un intero senza segno a 8 bit equivalente.

public static byte ToByte (string value, int fromBase);
public static byte ToByte (string? value, int fromBase);

Parametri

value
String

Stringa contenente il numero da convertire.

fromBase
Int32

Base del numero in value, che deve essere 2, 8, 10 o 16.

Restituisce

Intero senza segno a 8 bit equivalente al numero in valueo 0 (zero) se value è null.

Eccezioni

fromBase non è 2, 8, 10 o 16.

-o-

value, che rappresenta un numero non di base 10 senza segno, è preceduto da un segno negativo.

value contiene un carattere che non è una cifra valida nella base specificata da fromBase. Il messaggio di eccezione indica che non sono presenti cifre da convertire se il primo carattere in value non è valido; in caso contrario, il messaggio indica che value contiene caratteri finali non validi.

value, che rappresenta un numero senza segno di base 10, è preceduto da un segno negativo.

-o-

value rappresenta un numero minore di Byte.MinValue o maggiore di Byte.MaxValue.

Esempio

Nell'esempio seguente viene in alternativa eseguito un tentativo di interpretare una matrice di stringhe come rappresentazione di valori binari, ottali, decimali ed esadecimali.

using System;

public class Example
{
   public static void Main()
   {
      int[] bases = { 2, 8, 10, 16 };
      string[] values = { "-1", "1", "08", "0F", "11" , "12", "30",
                          "101", "255", "FF", "10000000", "80" };
      byte number;
      foreach (int numBase in bases)
      {
         Console.WriteLine("Base {0}:", numBase);
         foreach (string value in values)
         {
            try {
               number = Convert.ToByte(value, numBase);
               Console.WriteLine("   Converted '{0}' to {1}.", value, number);
            }
            catch (FormatException) {
               Console.WriteLine("   '{0}' is not in the correct format for a base {1} byte value.",
                                 value, numBase);
            }
            catch (OverflowException) {
               Console.WriteLine("   '{0}' is outside the range of the Byte type.", value);
            }
            catch (ArgumentException) {
               Console.WriteLine("   '{0}' is invalid in base {1}.", value, numBase);
            }
         }
      }
   }
}
// The example displays the following output:
//    Base 2:
//       '-1' is invalid in base 2.
//       Converted '1' to 1.
//       '08' is not in the correct format for a base 2 conversion.
//       '0F' is not in the correct format for a base 2 conversion.
//       Converted '11' to 3.
//       '12' is not in the correct format for a base 2 conversion.
//       '30' is not in the correct format for a base 2 conversion.
//       Converted '101' to 5.
//       '255' is not in the correct format for a base 2 conversion.
//       'FF' is not in the correct format for a base 2 conversion.
//       Converted '10000000' to 128.
//       '80' is not in the correct format for a base 2 conversion.
//    Base 8:
//       '-1' is invalid in base 8.
//       Converted '1' to 1.
//       '08' is not in the correct format for a base 8 conversion.
//       '0F' is not in the correct format for a base 8 conversion.
//       Converted '11' to 9.
//       Converted '12' to 10.
//       Converted '30' to 24.
//       Converted '101' to 65.
//       Converted '255' to 173.
//       'FF' is not in the correct format for a base 8 conversion.
//       '10000000' is outside the range of the Byte type.
//       '80' is not in the correct format for a base 8 conversion.
//    Base 10:
//       '-1' is outside the range of the Byte type.
//       Converted '1' to 1.
//       Converted '08' to 8.
//       '0F' is not in the correct format for a base 10 conversion.
//       Converted '11' to 11.
//       Converted '12' to 12.
//       Converted '30' to 30.
//       Converted '101' to 101.
//       Converted '255' to 255.
//       'FF' is not in the correct format for a base 10 conversion.
//       '10000000' is outside the range of the Byte type.
//       Converted '80' to 80.
//    Base 16:
//       '-1' is invalid in base 16.
//       Converted '1' to 1.
//       Converted '08' to 8.
//       Converted '0F' to 15.
//       Converted '11' to 17.
//       Converted '12' to 18.
//       Converted '30' to 48.
//       '101' is outside the range of the Byte type.
//       '255' is outside the range of the Byte type.
//       Converted 'FF' to 255.
//       '10000000' is outside the range of the Byte type.
//       Converted '80' to 128.

Commenti

Se fromBase è 16, è possibile anteporre il numero specificato dal parametro value con "0x" o "0X".

Poiché il tipo di dati Byte supporta solo valori senza segno, il metodo ToByte(String, Int32) presuppone che value venga espressa utilizzando una rappresentazione binaria senza segno. In altre parole, tutti e otto i bit vengono usati per rappresentare il valore numerico e un bit di segno è assente. Di conseguenza, è possibile scrivere codice in cui un valore di byte firmato non compreso nell'intervallo del tipo di dati Byte viene convertito in un valore Byte senza che il metodo generi un'eccezione. L'esempio seguente converte MinValue nella relativa rappresentazione di stringa esadecimale e quindi chiama il metodo ToByte(String, Int32). Anziché generare un'eccezione, il metodo visualizza il messaggio "0x80 converte in 128".

// Create a hexadecimal value out of range of the Byte type.
string value = SByte.MinValue.ToString("X");
// Convert it back to a number.
try
{
   byte number = Convert.ToByte(value, 16);
   Console.WriteLine("0x{0} converts to {1}.", value, number);
}
catch (OverflowException)
{
   Console.WriteLine("Unable to convert '0x{0}' to a byte.", value);
}

Quando si eseguono operazioni binarie o conversioni numeriche, è sempre responsabilità dello sviluppatore verificare che un metodo o un operatore usi la rappresentazione numerica appropriata per interpretare un determinato valore. Nell'esempio seguente viene illustrata una tecnica per garantire che il metodo non usi in modo inappropriato la rappresentazione binaria senza segno quando converte una rappresentazione di stringa esadecimale in un valore Byte. Nell'esempio viene determinato se un valore rappresenta un intero con segno o senza segno durante la conversione di tale valore nella relativa rappresentazione di stringa. Quando l'esempio converte nuovamente il valore in un valore Byte, verifica se il valore originale è un intero con segno. In tal caso, e se il bit di ordine elevato è impostato (che indica che il valore è negativo e che usa il complemento di due anziché una rappresentazione binaria senza segno), il metodo genera un'eccezione.

// Create a negative hexadecimal value out of range of the Byte type.
sbyte sourceNumber = SByte.MinValue;
bool isSigned = Math.Sign((sbyte)sourceNumber.GetType().GetField("MinValue").GetValue(null)) == -1;
string value = sourceNumber.ToString("X");
byte targetNumber;
try
{
   targetNumber = Convert.ToByte(value, 16);
   if (isSigned && ((targetNumber & 0x80) != 0))
      throw new OverflowException();
   else
      Console.WriteLine("0x{0} converts to {1}.", value, targetNumber);
}
catch (OverflowException)
{
   Console.WriteLine("Unable to convert '0x{0}' to an unsigned byte.", value);
}
// Displays the following to the console:
//    Unable to convert '0x80' to an unsigned byte.

Si applica a

ToByte(Object, IFormatProvider)

Origine:
Convert.cs
Origine:
Convert.cs
Origine:
Convert.cs

Converte il valore dell'oggetto specificato in un intero senza segno a 8 bit utilizzando le informazioni di formattazione specifiche delle impostazioni cultura specificate.

public static byte ToByte (object value, IFormatProvider provider);
public static byte ToByte (object? value, IFormatProvider? provider);

Parametri

value
Object

Oggetto che implementa l'interfaccia IConvertible.

provider
IFormatProvider

Oggetto che fornisce informazioni di formattazione specifiche delle impostazioni cultura.

Restituisce

Intero senza segno a 8 bit equivalente a valueo zero se value è null.

Eccezioni

value non è nel formato della proprietà per un valore Byte.

value non implementa IConvertible.

-o-

La conversione da value al tipo di Byte non è supportata.

value rappresenta un numero minore di Byte.MinValue o maggiore di Byte.MaxValue.

Esempio

Nell'esempio seguente viene definita una classe ByteString che implementa l'interfaccia IConvertible. La classe archivia la rappresentazione di stringa di un valore di byte insieme a un campo segno, in modo che sia in grado di rappresentare valori di byte firmati e senza segno.

using System;
using System.Globalization;

public enum SignBit { Negative=-1, Zero=0, Positive=1 };

public struct ByteString : IConvertible
{
   private SignBit signBit;
   private string byteString;

   public SignBit Sign
   {
      set { signBit = value; }
      get { return signBit; }
   }

   public string Value
   {
      set {
         if (value.Trim().Length > 2)
            throw new ArgumentException("The string representation of a byte cannot have more than two characters.");
         else
            byteString = value;
      }
      get { return byteString; }
   }

   // IConvertible implementations.
   public TypeCode GetTypeCode() {
      return TypeCode.Object;
   }

   public bool ToBoolean(IFormatProvider provider)
   {
      if (signBit == SignBit.Zero)
         return false;
      else
         return true;
   }

   public byte ToByte(IFormatProvider provider)
   {
      if (signBit == SignBit.Negative)
         throw new OverflowException(String.Format("{0} is out of range of the Byte type.", Convert.ToSByte(byteString, 16)));
      else
         return Byte.Parse(byteString, NumberStyles.HexNumber);
   }

   public char ToChar(IFormatProvider provider)
   {
      if (signBit == SignBit.Negative) {
         throw new OverflowException(String.Format("{0} is out of range of the Char type.", Convert.ToSByte(byteString, 16)));
      }
      else {
         byte byteValue = Byte.Parse(this.byteString, NumberStyles.HexNumber);
         return Convert.ToChar(byteValue);
      }
   }

   public DateTime ToDateTime(IFormatProvider provider)
   {
      throw new InvalidCastException("ByteString to DateTime conversion is not supported.");
   }

   public decimal ToDecimal(IFormatProvider provider)
   {
      if (signBit == SignBit.Negative)
      {
         sbyte byteValue = SByte.Parse(byteString, NumberStyles.HexNumber);
         return Convert.ToDecimal(byteValue);
      }
      else
      {
         byte byteValue = Byte.Parse(byteString, NumberStyles.HexNumber);
         return Convert.ToDecimal(byteValue);
      }
   }

   public double ToDouble(IFormatProvider provider)
   {
      if (signBit == SignBit.Negative)
         return Convert.ToDouble(SByte.Parse(byteString, NumberStyles.HexNumber));
      else
         return Convert.ToDouble(Byte.Parse(byteString, NumberStyles.HexNumber));
   }

   public short ToInt16(IFormatProvider provider)
   {
      if (signBit == SignBit.Negative)
         return Convert.ToInt16(SByte.Parse(byteString, NumberStyles.HexNumber));
      else
         return Convert.ToInt16(Byte.Parse(byteString, NumberStyles.HexNumber));
   }

   public int ToInt32(IFormatProvider provider)
   {
      if (signBit == SignBit.Negative)
         return Convert.ToInt32(SByte.Parse(byteString, NumberStyles.HexNumber));
      else
         return Convert.ToInt32(Byte.Parse(byteString, NumberStyles.HexNumber));
   }

   public long ToInt64(IFormatProvider provider)
   {
      if (signBit == SignBit.Negative)
         return Convert.ToInt64(SByte.Parse(byteString, NumberStyles.HexNumber));
      else
         return Convert.ToInt64(Byte.Parse(byteString, NumberStyles.HexNumber));
   }

   public sbyte ToSByte(IFormatProvider provider)
   {
      if (signBit == SignBit.Negative)
         try {
            return Convert.ToSByte(Byte.Parse(byteString, NumberStyles.HexNumber));
         }
         catch (OverflowException e) {
            throw new OverflowException(String.Format("{0} is outside the range of the SByte type.",
                                                   Byte.Parse(byteString, NumberStyles.HexNumber)), e);
         }
      else
         return SByte.Parse(byteString, NumberStyles.HexNumber);
   }

   public float ToSingle(IFormatProvider provider)
   {
      if (signBit == SignBit.Negative)
         return Convert.ToSingle(SByte.Parse(byteString, NumberStyles.HexNumber));
      else
         return Convert.ToSingle(Byte.Parse(byteString, NumberStyles.HexNumber));
   }

   public string ToString(IFormatProvider provider)
   {
      return "0x" + this.byteString;
   }

   public object ToType(Type conversionType, IFormatProvider provider)
   {
      switch (Type.GetTypeCode(conversionType))
      {
         case TypeCode.Boolean:
            return this.ToBoolean(null);
         case TypeCode.Byte:
            return this.ToByte(null);
         case TypeCode.Char:
            return this.ToChar(null);
         case TypeCode.DateTime:
            return this.ToDateTime(null);
         case TypeCode.Decimal:
            return this.ToDecimal(null);
         case TypeCode.Double:
            return this.ToDouble(null);
         case TypeCode.Int16:
            return this.ToInt16(null);
         case TypeCode.Int32:
            return this.ToInt32(null);
         case TypeCode.Int64:
            return this.ToInt64(null);
         case TypeCode.Object:
            if (typeof(ByteString).Equals(conversionType))
               return this;
            else
               throw new InvalidCastException(String.Format("Conversion to a {0} is not supported.", conversionType.Name));
         case TypeCode.SByte:
            return this.ToSByte(null);
         case TypeCode.Single:
            return this.ToSingle(null);
         case TypeCode.String:
            return this.ToString(null);
         case TypeCode.UInt16:
            return this.ToUInt16(null);
         case TypeCode.UInt32:
            return this.ToUInt32(null);
         case TypeCode.UInt64:
            return this.ToUInt64(null);
         default:
            throw new InvalidCastException(String.Format("Conversion to {0} is not supported.", conversionType.Name));
      }
   }

   public UInt16 ToUInt16(IFormatProvider provider)
   {
      if (signBit == SignBit.Negative)
         throw new OverflowException(String.Format("{0} is outside the range of the UInt16 type.",
                                                   SByte.Parse(byteString, NumberStyles.HexNumber)));
      else
         return Convert.ToUInt16(Byte.Parse(byteString, NumberStyles.HexNumber));
   }

   public UInt32 ToUInt32(IFormatProvider provider)
   {
      if (signBit == SignBit.Negative)
         throw new OverflowException(String.Format("{0} is outside the range of the UInt32 type.",
                                                   SByte.Parse(byteString, NumberStyles.HexNumber)));
      else
         return Convert.ToUInt32(Byte.Parse(byteString, NumberStyles.HexNumber));
   }

   public UInt64 ToUInt64(IFormatProvider provider)
   {
      if (signBit == SignBit.Negative)
         throw new OverflowException(String.Format("{0} is outside the range of the UInt64 type.",
                                                   SByte.Parse(byteString, NumberStyles.HexNumber)));
      else
         return Convert.ToUInt64(Byte.Parse(byteString, NumberStyles.HexNumber));
   }
}

Nell'esempio seguente viene creata un'istanza di diversi oggetti ByteString e viene chiamato il metodo ToByte(Object, IFormatProvider) per convertirli in valori di byte. Illustra che il metodo ToByte(Object, IFormatProvider) esegue il wrapping di una chiamata al metodo IConvertible.ToByte dell'oggetto da convertire.

public class Class1
{
   public static void Main()
   {
      byte positiveByte = 216;
      sbyte negativeByte = -101;

      ByteString positiveString = new ByteString();
      positiveString.Sign = (SignBit) Math.Sign(positiveByte);
      positiveString.Value = positiveByte.ToString("X2");

      ByteString negativeString = new ByteString();
      negativeString.Sign = (SignBit) Math.Sign(negativeByte);
      negativeString.Value = negativeByte.ToString("X2");

      try {
         Console.WriteLine("'{0}' converts to {1}.", positiveString.Value, Convert.ToByte(positiveString));
      }
      catch (OverflowException) {
         Console.WriteLine("0x{0} is outside the range of the Byte type.", positiveString.Value);
      }

      try {
         Console.WriteLine("'{0}' converts to {1}.", negativeString.Value, Convert.ToByte(negativeString));
      }
      catch (OverflowException) {
         Console.WriteLine("0x{0} is outside the range of the Byte type.", negativeString.Value);
      }
   }
}
// The example displays the following output:
//       'D8' converts to 216.
//       0x9B is outside the range of the Byte type.

Commenti

provider consente all'utente di specificare informazioni di conversione specifiche delle impostazioni cultura relative al contenuto di value. I tipi di base ignorano provider; Tuttavia, il parametro può essere usato se value è un tipo definito dall'utente che implementa l'interfaccia IConvertible.

Si applica a

ToByte(String, IFormatProvider)

Origine:
Convert.cs
Origine:
Convert.cs
Origine:
Convert.cs

Converte la rappresentazione di stringa specificata di un numero in un intero senza segno a 8 bit equivalente, utilizzando le informazioni di formattazione specifiche delle impostazioni cultura specificate.

public static byte ToByte (string value, IFormatProvider provider);
public static byte ToByte (string? value, IFormatProvider? provider);

Parametri

value
String

Stringa contenente il numero da convertire.

provider
IFormatProvider

Oggetto che fornisce informazioni di formattazione specifiche delle impostazioni cultura.

Restituisce

Intero senza segno a 8 bit equivalente a valueo zero se value è null.

Eccezioni

value non è costituito da un segno facoltativo seguito da una sequenza di cifre (da 0 a 9).

value rappresenta un numero minore di Byte.MinValue o maggiore di Byte.MaxValue.

Esempio

Nell'esempio seguente viene creato un oggetto NumberFormatInfo personalizzato che definisce il segno positivo come "pos" e il segno negativo come "neg", usato nelle chiamate al metodo ToByte(String, IFormatProvider). Chiama quindi ripetutamente il metodo ToByte(String, IFormatProvider) per convertire ogni elemento in una matrice di stringhe in un valore Byte.

using System;
using System.Globalization;

public class Example
{
   public static void Main()
   {
      // Create a NumberFormatInfo object and set several of its
      // properties that apply to unsigned bytes.
      NumberFormatInfo provider = new NumberFormatInfo();

      // These properties affect the conversion.
      provider.PositiveSign = "pos ";
      provider.NegativeSign = "neg ";

      // This property does not affect the conversion.
      // The input string cannot have a decimal separator.
      provider.NumberDecimalSeparator = ".";

      // Define an array of numeric strings.
      string[] numericStrings = { "234", "+234", "pos 234", "234.", "255",
                                  "256", "-1" };

      foreach (string numericString in numericStrings)
      {
         Console.Write("'{0,-8}' ->   ", numericString);
         try {
            byte number = Convert.ToByte(numericString, provider);
            Console.WriteLine(number);
         }
         catch (FormatException) {
            Console.WriteLine("Incorrect Format");
         }
         catch (OverflowException) {
            Console.WriteLine("Overflows a Byte");
         }
      }
   }
}
// The example displays the following output:
//       '234     ' ->   234
//       '+234    ' ->   Incorrect Format
//       'pos 234 ' ->   234
//       '234.    ' ->   Incorrect Format
//       '255     ' ->   255
//       '256     ' ->   Overflows a Byte
//       '-1      ' ->   Incorrect Format

Commenti

provider è un'istanza di IFormatProvider che ottiene un oggetto NumberFormatInfo. L'oggetto NumberFormatInfo fornisce informazioni specifiche delle impostazioni cultura sul formato di value. Se provider è null, viene utilizzato l'oggetto NumberFormatInfo per le impostazioni cultura correnti.

Se si preferisce non gestire un'eccezione se la conversione non riesce, è possibile chiamare invece il metodo Byte.TryParse. Restituisce un valore Boolean che indica se la conversione ha avuto esito positivo o negativo.

Vedi anche

Si applica a

ToByte(Single)

Origine:
Convert.cs
Origine:
Convert.cs
Origine:
Convert.cs

Converte il valore del numero a virgola mobile e precisione singola specificato in un intero senza segno a 8 bit equivalente.

public static byte ToByte (float value);

Parametri

value
Single

Numero a virgola mobile e precisione singola.

Restituisce

value, arrotondato all'intero senza segno a 8 bit più vicino. Se value è a metà strada tra due numeri interi, viene restituito il numero pari; ovvero 4,5 viene convertito in 4 e 5,5 viene convertito in 6.

Eccezioni

value è maggiore di Byte.MaxValue o minore di Byte.MinValue.

Esempio

Nell'esempio seguente viene convertito un valore Single in un Byte.

public void ConvertByteSingle(byte byteVal) {
    float floatVal;

    // Byte to float conversion will not overflow.
    floatVal = System.Convert.ToSingle(byteVal);
    System.Console.WriteLine("The byte as a float is {0}.",
        floatVal);

    // Float to byte conversion can overflow.
    try {
        byteVal = System.Convert.ToByte(floatVal);
        System.Console.WriteLine("The float as a byte is {0}.",
            byteVal);
    }
    catch (System.OverflowException) {
        System.Console.WriteLine(
            "The float value is too large for a byte.");
    }
}

Vedi anche

Si applica a

ToByte(UInt64)

Origine:
Convert.cs
Origine:
Convert.cs
Origine:
Convert.cs

Importante

Questa API non è conforme a CLS.

Converte il valore dell'intero senza segno a 64 bit specificato in un intero senza segno a 8 bit equivalente.

[System.CLSCompliant(false)]
public static byte ToByte (ulong value);

Parametri

value
UInt64

Intero senza segno a 64 bit da convertire.

Restituisce

Intero senza segno a 8 bit equivalente a value.

Attributi

Eccezioni

value è maggiore di Byte.MaxValue.

Esempio

Nell'esempio seguente viene convertita una matrice di interi long senza segno in valori Byte.

ulong[] numbers= { UInt64.MinValue, 121, 340, UInt64.MaxValue };
byte result;
foreach (ulong number in numbers)
{
   try {
      result = Convert.ToByte(number);
      Console.WriteLine("Converted the {0} value {1} to the {2} value {3}.",
                        number.GetType().Name, number,
                        result.GetType().Name, result);
   }
   catch (OverflowException)
   {
      Console.WriteLine("The {0} value {1} is outside the range of the Byte type.",
                        number.GetType().Name, number);
   }
}
// The example displays the following output:
//       Converted the UInt64 value 0 to the Byte value 0.
//       Converted the UInt64 value 121 to the Byte value 121.
//       The UInt64 value 340 is outside the range of the Byte type.
//       The UInt64 value 18446744073709551615 is outside the range of the Byte type.

Si applica a

ToByte(SByte)

Origine:
Convert.cs
Origine:
Convert.cs
Origine:
Convert.cs

Importante

Questa API non è conforme a CLS.

Converte il valore dell'intero con segno a 8 bit specificato in un intero senza segno a 8 bit equivalente.

[System.CLSCompliant(false)]
public static byte ToByte (sbyte value);

Parametri

value
SByte

Intero con segno a 8 bit da convertire.

Restituisce

Intero senza segno a 8 bit equivalente a value.

Attributi

Eccezioni

value è minore di Byte.MinValue.

Esempio

Nell'esempio seguente viene convertita una matrice di valori SByte in valori Byte.

sbyte[] numbers = { SByte.MinValue, -1, 0, 10, SByte.MaxValue };
byte result;
foreach (sbyte number in numbers)
{
   try {
      result = Convert.ToByte(number);
      Console.WriteLine("Converted the {0} value {1} to the {2} value {3}.",
                        number.GetType().Name, number,
                        result.GetType().Name, result);
   }
   catch (OverflowException)
   {
      Console.WriteLine("The {0} value {1} is outside the range of the Byte type.",
                        number.GetType().Name, number);
   }
}
// The example displays the following output:
//       The SByte value -128 is outside the range of the Byte type.
//       The SByte value -1 is outside the range of the Byte type.
//       Converted the SByte value 0 to the Byte value 0.
//       Converted the SByte value 10 to the Byte value 10.
//       Converted the SByte value 127 to the Byte value 127.

Si applica a

ToByte(DateTime)

Origine:
Convert.cs
Origine:
Convert.cs
Origine:
Convert.cs

La chiamata a questo metodo genera sempre InvalidCastException.

public static byte ToByte (DateTime value);

Parametri

value
DateTime

Valore di data e ora da convertire.

Restituisce

Questa conversione non è supportata. Non viene restituito alcun valore.

Eccezioni

Questa conversione non è supportata.

Si applica a

ToByte(Int64)

Origine:
Convert.cs
Origine:
Convert.cs
Origine:
Convert.cs

Converte il valore dell'intero con segno a 64 bit specificato in un intero senza segno a 8 bit equivalente.

public static byte ToByte (long value);

Parametri

value
Int64

Intero con segno a 64 bit da convertire.

Restituisce

Intero senza segno a 8 bit equivalente a value.

Eccezioni

value è minore di Byte.MinValue o maggiore di Byte.MaxValue.

Esempio

Nell'esempio seguente viene convertita una matrice di valori Int64 in valori Byte.

long[] numbers = { Int64.MinValue, -1, 0, 121, 340, Int64.MaxValue };
byte result;
foreach (long number in numbers)
{
   try {
      result = Convert.ToByte(number);
      Console.WriteLine("Converted the {0} value {1} to the {2} value {3}.",
                        number.GetType().Name, number,
                        result.GetType().Name, result);
   }
   catch (OverflowException) {
      Console.WriteLine("The {0} value {1} is outside the range of the Byte type.",
                        number.GetType().Name, number);
   }
}
// The example displays the following output:
//       The Int64 value -9223372036854775808 is outside the range of the Byte type.
//       The Int64 value -1 is outside the range of the Byte type.
//       Converted the Int64 value 0 to the Byte value 0.
//       Converted the Int64 value 121 to the Byte value 121.
//       The Int64 value 340 is outside the range of the Byte type.
//       The Int64 value 9223372036854775807 is outside the range of the Byte type.

Si applica a

ToByte(Byte)

Origine:
Convert.cs
Origine:
Convert.cs
Origine:
Convert.cs

Restituisce l'intero senza segno a 8 bit specificato; non viene eseguita alcuna conversione effettiva.

public static byte ToByte (byte value);

Parametri

value
Byte

Intero senza segno a 8 bit da restituire.

Restituisce

value viene restituito invariato.

Si applica a

ToByte(Char)

Origine:
Convert.cs
Origine:
Convert.cs
Origine:
Convert.cs

Converte il valore del carattere Unicode specificato nell'intero senza segno a 8 bit equivalente.

public static byte ToByte (char value);

Parametri

value
Char

Carattere Unicode da convertire.

Restituisce

Intero senza segno a 8 bit equivalente a value.

Eccezioni

value rappresenta un numero maggiore di Byte.MaxValue.

Esempio

Nell'esempio seguente viene convertita una matrice di valori Char in valori Byte.

char[] chars = { 'a', 'z', '\x0007', '\x03FF' };
foreach (char ch in chars)
{
   try {
      byte result = Convert.ToByte(ch);
      Console.WriteLine("{0} is converted to {1}.", ch, result);
   }
   catch (OverflowException) {
      Console.WriteLine("Unable to convert u+{0} to a byte.",
                        Convert.ToInt16(ch).ToString("X4"));
   }
}
// The example displays the following output:
//       a is converted to 97.
//       z is converted to 122.
//        is converted to 7.
//       Unable to convert u+03FF to a byte.

Commenti

Questo metodo restituisce un valore byte senza segno che rappresenta il codice numerico dell'oggetto Char passato. In .NET un oggetto Char è un valore a 16 bit. Ciò significa che il metodo è adatto per restituire i codici numerici di caratteri nell'intervallo di caratteri ASCII o nei controlli Unicode C0 e i controlli latini di base e I controlli C1 e alfabeto latino-1, da U+0000 a U+00FF.

Si applica a

ToByte(Decimal)

Origine:
Convert.cs
Origine:
Convert.cs
Origine:
Convert.cs

Converte il valore del numero decimale specificato in un intero senza segno a 8 bit equivalente.

public static byte ToByte (decimal value);

Parametri

value
Decimal

Numero da convertire.

Restituisce

value, arrotondato all'intero senza segno a 8 bit più vicino. Se value è a metà strada tra due numeri interi, viene restituito il numero pari; ovvero 4,5 viene convertito in 4 e 5,5 viene convertito in 6.

Eccezioni

value è maggiore di Byte.MaxValue o minore di Byte.MinValue.

Commenti

Nell'esempio seguente un valore di Byte viene convertito in un valore Decimal e un valore Decimal in un Byte.

public void ConvertByteDecimal(byte byteVal) {
    decimal decimalVal;

    // Byte to decimal conversion will not overflow.
    decimalVal = System.Convert.ToDecimal(byteVal);
    System.Console.WriteLine("The byte as a decimal is {0}.",
        decimalVal);

    // Decimal to byte conversion can overflow.
    try {
        byteVal = System.Convert.ToByte(decimalVal);
        System.Console.WriteLine("The Decimal as a byte is {0}.",
            byteVal);
    }
    catch (System.OverflowException) {
        System.Console.WriteLine(
            "The decimal value is too large for a byte.");
    }
}

Si applica a

ToByte(Boolean)

Origine:
Convert.cs
Origine:
Convert.cs
Origine:
Convert.cs

Converte il valore booleano specificato nell'intero senza segno a 8 bit equivalente.

public static byte ToByte (bool value);

Parametri

value
Boolean

Valore booleano da convertire.

Restituisce

Numero 1 se value è true; in caso contrario, 0.

Esempio

Nell'esempio seguente viene illustrata la conversione di Boolean in valori Byte.

bool falseFlag = false;
bool trueFlag = true;

Console.WriteLine("{0} converts to {1}.", falseFlag,
                  Convert.ToByte(falseFlag));
Console.WriteLine("{0} converts to {1}.", trueFlag,
                  Convert.ToByte(trueFlag));
// The example displays the following output:
//       False converts to 0.
//       True converts to 1.

Si applica a

ToByte(Int16)

Origine:
Convert.cs
Origine:
Convert.cs
Origine:
Convert.cs

Converte il valore dell'intero con segno a 16 bit specificato in un intero senza segno a 8 bit equivalente.

public static byte ToByte (short value);

Parametri

value
Int16

Intero con segno a 16 bit da convertire.

Restituisce

Intero senza segno a 8 bit equivalente a value.

Eccezioni

value è minore di Byte.MinValue o maggiore di Byte.MaxValue.

Esempio

Nell'esempio seguente viene convertita una matrice di valori Int16 in valori Byte.

short[] numbers = { Int16.MinValue, -1, 0, 121, 340, Int16.MaxValue };
byte result;
foreach (short number in numbers)
{
   try {
      result = Convert.ToByte(number);
      Console.WriteLine("Converted the {0} value {1} to the {2} value {3}.",
                        number.GetType().Name, number,
                        result.GetType().Name, result);
   }
   catch (OverflowException) {
      Console.WriteLine("The {0} value {1} is outside the range of the Byte type.",
                        number.GetType().Name, number);
   }
}
// The example displays the following output:
//       The Int16 value -32768 is outside the range of the Byte type.
//       The Int16 value -1 is outside the range of the Byte type.
//       Converted the Int16 value 0 to the Byte value 0.
//       Converted the Int16 value 121 to the Byte value 121.
//       The Int16 value 340 is outside the range of the Byte type.
//       The Int16 value 32767 is outside the range of the Byte type.

Si applica a

ToByte(Int32)

Origine:
Convert.cs
Origine:
Convert.cs
Origine:
Convert.cs

Converte il valore dell'intero con segno a 32 bit specificato in un intero senza segno a 8 bit equivalente.

public static byte ToByte (int value);

Parametri

value
Int32

Intero con segno a 32 bit da convertire.

Restituisce

Intero senza segno a 8 bit equivalente a value.

Eccezioni

value è minore di Byte.MinValue o maggiore di Byte.MaxValue.

Esempio

Nell'esempio seguente viene convertita una matrice di valori Int32 in valori Byte.

int[] numbers = { Int32.MinValue, -1, 0, 121, 340, Int32.MaxValue };
byte result;
foreach (int number in numbers)
{
   try {
      result = Convert.ToByte(number);
      Console.WriteLine("Converted the {0} value {1} to the {2} value {3}.",
                        number.GetType().Name, number,
                        result.GetType().Name, result);
   }
   catch (OverflowException) {
      Console.WriteLine("The {0} value {1} is outside the range of the Byte type.",
                        number.GetType().Name, number);
   }
}
// The example displays the following output:
//       The Int32 value -2147483648 is outside the range of the Byte type.
//       The Int32 value -1 is outside the range of the Byte type.
//       Converted the Int32 value 0 to the Byte value 0.
//       Converted the Int32 value 121 to the Byte value 121.
//       The Int32 value 340 is outside the range of the Byte type.
//       The Int32 value 2147483647 is outside the range of the Byte type.

Si applica a

ToByte(Double)

Origine:
Convert.cs
Origine:
Convert.cs
Origine:
Convert.cs

Converte il valore del numero a virgola mobile e precisione doppia specificato in un intero senza segno a 8 bit equivalente.

public static byte ToByte (double value);

Parametri

value
Double

Numero a virgola mobile e precisione doppia da convertire.

Restituisce

value, arrotondato all'intero senza segno a 8 bit più vicino. Se value è a metà strada tra due numeri interi, viene restituito il numero pari; ovvero 4,5 viene convertito in 4 e 5,5 viene convertito in 6.

Eccezioni

value è maggiore di Byte.MaxValue o minore di Byte.MinValue.

Esempio

Nell'esempio seguente un valore di Byte viene convertito in un valore Double e un valore Double in un Byte.

public void ConvertDoubleByte(double doubleVal) {
    byte	byteVal = 0;

    // Double to byte conversion can overflow.
    try {
        byteVal = System.Convert.ToByte(doubleVal);
        System.Console.WriteLine("{0} as a byte is: {1}.",
            doubleVal, byteVal);
    }
    catch (System.OverflowException) {
        System.Console.WriteLine(
            "Overflow in double-to-byte conversion.");
    }

    // Byte to double conversion cannot overflow.
    doubleVal = System.Convert.ToDouble(byteVal);
    System.Console.WriteLine("{0} as a double is: {1}.",
        byteVal, doubleVal);
}

Si applica a

ToByte(Object)

Origine:
Convert.cs
Origine:
Convert.cs
Origine:
Convert.cs

Converte il valore dell'oggetto specificato in un intero senza segno a 8 bit.

public static byte ToByte (object value);
public static byte ToByte (object? value);

Parametri

value
Object

Oggetto che implementa l'interfaccia IConvertible o null.

Restituisce

Intero senza segno a 8 bit equivalente a valueo zero se value è null.

Eccezioni

value non è nel formato della proprietà per un valore Byte.

value non implementa IConvertible.

-o-

La conversione da value al tipo di Byte non è supportata.

value rappresenta un numero minore di Byte.MinValue o maggiore di Byte.MaxValue.

Esempio

Nell'esempio seguente viene utilizzato il metodo ToByte(Object) per convertire una matrice di oggetti in valori Byte.

object[] values = { true, -12, 163, 935, 'x', "104", "103.0", "-1",
                    "1.00e2", "One", 1.00e2};
byte result;
foreach (object value in values)
{
   try {
      result = Convert.ToByte(value);
      Console.WriteLine("Converted the {0} value {1} to the {2} value {3}.",
                        value.GetType().Name, value,
                        result.GetType().Name, result);
   }
   catch (OverflowException)
   {
      Console.WriteLine("The {0} value {1} is outside the range of the Byte type.",
                        value.GetType().Name, value);
   }
   catch (FormatException)
   {
      Console.WriteLine("The {0} value {1} is not in a recognizable format.",
                        value.GetType().Name, value);
   }
   catch (InvalidCastException)
   {
      Console.WriteLine("No conversion to a Byte exists for the {0} value {1}.",
                        value.GetType().Name, value);
   }
}
// The example displays the following output:
//       Converted the Boolean value True to the Byte value 1.
//       The Int32 value -12 is outside the range of the Byte type.
//       Converted the Int32 value 163 to the Byte value 163.
//       The Int32 value 935 is outside the range of the Byte type.
//       Converted the Char value x to the Byte value 120.
//       Converted the String value 104 to the Byte value 104.
//       The String value 103.0 is not in a recognizable format.
//       The String value -1 is outside the range of the Byte type.
//       The String value 1.00e2 is not in a recognizable format.
//       The String value One is not in a recognizable format.
//       Converted the Double value 100 to the Byte value 100.

Commenti

Se value non è null, questo metodo esegue il wrapping di una chiamata all'implementazione IConvertible.ToByte del tipo sottostante di value.

Si applica a