Este método se utiliza para devolver un número de punto flotante de precisión simple convertido a partir de cuatro bytes en una posición específica en una array de bytes.
Sintaxis:
public static float ToSingle (byte[] value, int startIndex);
Parámetros:
valor: Es una array de bytes.
startIndex: Es la posición inicial dentro del valor.
Valor devuelto: este método devuelve un número de punto flotante de precisión simple formado por cuatro bytes que comienzan en startIndex.
Excepciones:
- ArgumentException: si startIndex es mayor o igual que la longitud del valor menos 3 y es menor o igual que la longitud del valor menos 1.
- ArgumentNullException: si el valor es nulo.
- ArgumentOutOfRangeException: si startIndex es menor que cero o mayor que la longitud del valor menos 1.
Los siguientes programas ilustran el uso del método BitConverter.ToSingle(Byte[], Int32) :
Ejemplo 1:
// C# program to demonstrate // BitConverter.ToSingle(Byte[], Int32) // Method using System; class GFG { // Main Method public static void Main() { try { // Define an array of byte values. byte[] bytes = {0, 128, 63, 0, 0, 112, 65, 0, 255, 127, 71, 0, 0, 128, 59, 0, 0, 128, 47, 73, 70, 131, 5, 75, 6, 158, 63}; // Display the values of the myArr. Console.Write("Initial Array: "); // calling the PrintIndexAndValues() // method to print PrintIndexAndValues(bytes); // print char value Console.WriteLine("index Array elements float values"); Console.WriteLine(); // getting float value and Display it for (int index = 0; index < bytes.Length - 3; index = index + 4) { float values = BitConverter.ToSingle(bytes, index); Console.WriteLine(" {0} {1} {2}", index, BitConverter.ToString(bytes, index, 4), values); } } catch (ArgumentNullException e) { Console.Write("Exception Thrown: "); Console.Write("{0}", e.GetType(), e.Message); } catch (ArgumentOutOfRangeException e) { Console.Write("Exception Thrown: "); Console.Write("{0}", e.GetType(), e.Message); } catch (ArgumentException e) { Console.Write("Exception Thrown: "); Console.Write("{0}", e.GetType(), e.Message); } } // Defining the method // PrintIndexAndValues public static void PrintIndexAndValues(byte[] myArr) { for (int i = 0; i < myArr.Length; i++) { Console.Write("{0} ", myArr[i]); } Console.WriteLine(); Console.WriteLine(); } }
Producción:
Initial Array: 0 128 63 0 0 112 65 0 255 127 71 0 0 128 59 0 0 128 47 73 70 131 5 75 6 158 63 index Array elements float values 0 00-80-3F-00 5.831554E-39 4 00-70-41-00 6.009485E-39 8 FF-7F-47-00 6.566237E-39 12 00-80-3B-00 5.464212E-39 16 00-80-2F-49 718848 20 46-83-05-4B 8749894
Ejemplo 2: para ArgumentException
// C# program to demonstrate // BitConverter.ToSingle(Byte[], Int32) // Method using System; class GFG { // Main Method public static void Main() { try { // Define an array of byte values. byte[] bytes ={0, 128, 63, 0, 0, 112, 65, 0, 255, 127, 71, 0, 0, 128, 59, 0, 0, 128, 47, 73, 70, 131, 5, 75, 6, 158, 63}; // Display the values of the myArr. Console.Write("Initial Array: "); // calling the PrintIndexAndValues() // method to print PrintIndexAndValues(bytes); // print char value Console.WriteLine("index Array elements"+ " float values"); Console.WriteLine(); // getting float value and Display it for (int index = 0; index < bytes.Length - 2; index = index + 4) { if (index == bytes.Length - 3) { Console.WriteLine(); Console.WriteLine("startIndex is equal to"+ " the length of bytes minus 3"); float values = BitConverter.ToSingle(bytes, index); Console.WriteLine(" {0} {1} {2}", index, BitConverter.ToString(bytes, index, 4), values); } else { float values = BitConverter.ToSingle(bytes, index); Console.WriteLine(" {0} {1} {2}", index, BitConverter.ToString(bytes, index, 4), values); } } } catch (ArgumentNullException e) { Console.Write("Exception Thrown: "); Console.Write("{0}", e.GetType(), e.Message); } catch (ArgumentOutOfRangeException e) { Console.Write("Exception Thrown: "); Console.Write("{0}", e.GetType(), e.Message); } catch (ArgumentException e) { Console.Write("Exception Thrown: "); Console.Write("{0}", e.GetType(), e.Message); } } // Defining the method // PrintIndexAndValues public static void PrintIndexAndValues(byte[] myArr) { for (int i = 0; i < myArr.Length; i++) { Console.Write("{0} ", myArr[i]); } Console.WriteLine(); Console.WriteLine(); } }
Producción:
Initial Array: 0 128 63 0 0 112 65 0 255 127 71 0 0 128 59 0 0 128 47 73 70 131 5 75 6 158 63 index Array elements float values 0 00-80-3F-00 5.831554E-39 4 00-70-41-00 6.009485E-39 8 FF-7F-47-00 6.566237E-39 12 00-80-3B-00 5.464212E-39 16 00-80-2F-49 718848 20 46-83-05-4B 8749894 startIndex is equal to the length of bytes minus 3 Exception Thrown: System.ArgumentException
Ejemplo 3: para ArgumentOutOfRangeException
// C# program to demonstrate // BitConverter.ToSingle(Byte[], Int32) // Method using System; using System.Collections.Generic; public class GFG { // Main Method public static void Main() { try { // Define an array of byte values. byte[] bytes = {0, 128, 63, 0, 0, 112, 65, 0, 255, 127, 71, 0, 0, 128, 59, 0, 0, 128, 47, 73, 70, 131, 5, 75, 6, 158, 63, 24}; // Display the values of the myArr. Console.Write("Initial Array: "); // calling the PrintIndexAndValues() // method to print PrintIndexAndValues(bytes); // print char value Console.WriteLine("index Array elements float values"); Console.WriteLine(); // getting float value and Display it for (int index = 0; index < bytes.Length + 1; index = index + 4) { if (index == bytes.Length) { Console.WriteLine(); Console.WriteLine("startIndex is greater than "+ "the length of bytes minus 1."); float values = BitConverter.ToSingle(bytes, index); Console.WriteLine(" {0} {1} {2}", index, BitConverter.ToString(bytes, index, 4), values); } else { float values = BitConverter.ToSingle(bytes, index); Console.WriteLine(" {0} {1} {2}", index, BitConverter.ToString(bytes, index, 4), values); } } } catch (ArgumentNullException e) { Console.Write("Exception Thrown: "); Console.Write("{0}", e.GetType(), e.Message); } catch (ArgumentOutOfRangeException e) { Console.Write("Exception Thrown: "); Console.Write("{0}", e.GetType(), e.Message); } catch (ArgumentException e) { Console.Write("Exception Thrown: "); Console.Write("{0}", e.GetType(), e.Message); } } // Defining the method // PrintIndexAndValues public static void PrintIndexAndValues(byte[] myArr) { for (int i = 0; i < myArr.Length; i++) { Console.Write("{0} ", myArr[i]); } Console.WriteLine(); Console.WriteLine(); } }
Producción:
Initial Array: 0 128 63 0 0 112 65 0 255 127 71 0 0 128 59 0 0 128 47 73 70 131 5 75 6 158 63 24 index Array elements float values 0 00-80-3F-00 5.831554E-39 4 00-70-41-00 6.009485E-39 8 FF-7F-47-00 6.566237E-39 12 00-80-3B-00 5.464212E-39 16 00-80-2F-49 718848 20 46-83-05-4B 8749894 24 06-9E-3F-18 2.476595E-24 startIndex is greater than the length of bytes minus 1. Exception Thrown: System.ArgumentOutOfRangeException
Ejemplo 4: Para ArgumentNullException
// C# program to demonstrate // BitConverter.ToSingle(Byte[], Int32) // Method using System; class GFG { // Main Method public static void Main() { try { // Define an array of byte // values with null value byte[] bytes = null; // getting the float value float values = BitConverter.ToSingle(bytes, 0); Console.Write("{0}", values); } catch (ArgumentNullException e) { Console.Write("Exception Thrown: "); Console.Write("{0}", e.GetType(), e.Message); } catch (ArgumentOutOfRangeException e) { Console.Write("Exception Thrown: "); Console.Write("{0}", e.GetType(), e.Message); } catch (ArgumentException e) { Console.Write("Exception Thrown: "); Console.Write("{0}", e.GetType(), e.Message); } } }
Producción:
Exception Thrown: System.ArgumentNullException
Referencia:
Publicación traducida automáticamente
Artículo escrito por RohitPrasad3 y traducido por Barcelona Geeks. The original can be accessed here. Licence: CCBY-SA