C# | Método Convert.ToInt64(String, IFormatProvider)

Este método se usa para convertir la representación de string especificada de un número en un entero equivalente de 64 bits con signo, usando la información de formato específica de la referencia cultural especificada.

Sintaxis:

public static long ToInt64 (string value, IFormatProvider provider);

Parámetros:

  • valor: Es una string que contiene el número a convertir.
  • proveedor: es un objeto que proporciona información de formato específica de la cultura.

Valor devuelto: este método devuelve un número decimal que es equivalente al número en value , o 0 (cero) si value es nulo .

Excepciones:

  • FormatException: si el valor no consta de un signo opcional seguido de una secuencia de dígitos (0 a 9).
  • OverFlowException: si el valor representa un número menor que MinValue o mayor que MaxValue .

Los siguientes programas ilustran el uso del método Convert.ToInt64(String, IFormatProvider) :

Ejemplo 1:

// C# program to demonstrate the
// Convert.ToInt64() Method
using System;
using System.Globalization;
  
class GFG {
  
// Main Method
public static void Main()
{
    try {
  
        // creating object of CultureInfo
        CultureInfo cultures = new CultureInfo("en-US");
  
        // declaring and initializing String array
        string[] values = {"12345", "+12345",
                                   "-12345"};
  
        // calling get() Method
        Console.Write("Converted long value"
                    + " from a specified string ");
  
        for (int j = 0; j < values.Length; j++) 
        {
            get(values[j], cultures);
        }
    }
  
    catch (FormatException e)
    {
        Console.WriteLine("\n");
        Console.Write("Exception Thrown: ");
        Console.Write("{0}", e.GetType(), e.Message);
    }
  
    catch (OverflowException e)
    {
        Console.WriteLine("\n");
        Console.Write("Exception Thrown: ");
        Console.Write("{0}", e.GetType(), e.Message);
    }
}
  
// Defining get() method
public static void get(string s,
           CultureInfo cultures)
{
  
    // converting string to specified long
    long val = Convert.ToInt64(s, cultures);
  
    // display the converted long value
    Console.Write(" {0}, ", val);
}
}
Producción:

Converted long value from a specified string  12345,  12345,  -12345,

Ejemplo 2: para FormatException

// C# program to demonstrate the
// Convert.ToInt64() Method
using System;
using System.Globalization;
  
class GFG {
  
// Main Method
public static void Main()
{
      
    try {
  
        // creating object of CultureInfo
        CultureInfo cultures = new CultureInfo("en-US");
  
        // declaring and initializing String array
        string[] values = {"12345", "+12345",
                                   "-12345"};
  
        // calling get() Method
        Console.Write("Converted long value"
                    + " of specified strings: ");
  
        for (int j = 0; j < values.Length; j++) 
        {
            get(values[j], cultures);
        }
  
        Console.WriteLine("\n");
        string s = "123 456, 789";
  
        Console.WriteLine("format of s is invalid ");
  
        // converting string to specified char
        long val = Convert.ToInt64(s, cultures);
  
        // display the converted char value
        Console.Write(" {0}, ", val);
    }
  
    catch (FormatException e)
    {
        Console.Write("Exception Thrown: ");
        Console.Write("{0}", e.GetType(), e.Message);
    }
  
    catch (OverflowException e) 
    {
        Console.Write("Exception Thrown: ");
        Console.Write("{0}", e.GetType(), e.Message);
    }
}
  
// Defining get() method
public static void get(string s,
           CultureInfo cultures)
{
  
    // converting string to
    // specified long value
    long val = Convert.ToInt64(s, cultures);
  
    // display the converted
    // decimal value
    Console.Write(" {0}, ", val);
}
}
Producción:

Converted long value of specified strings:  12345,  12345,  -12345, 

format of s is invalid 
Exception Thrown: System.FormatException

Ejemplo 3: para OverflowException

// C# program to demonstrate the
// Convert.ToInt64() Method
using System;
using System.Globalization;
  
class GFG {
  
// Main Method
public static void Main()
{
  
    try {
  
        // creating object of CultureInfo
        CultureInfo cultures = new CultureInfo("en-US");
  
        // declaring and initializing String array
        string[] values = {"12345", "+12345",
                                   "-12345"};
  
        // calling get() Method
        Console.Write("Converted long value "
                 + "of specified strings: ");
  
        for (int j = 0; j < values.Length; j++)
        {
            get(values[j], cultures);
        }
  
        Console.WriteLine("\n");
        string s = "-7922816251426433759354395033500000";
  
        Console.WriteLine("s is less than the MinValue");
  
        // converting string to specified long
        long val = Convert.ToInt64(s, cultures);
  
        // display the converted char value
        Console.Write(" {0}, ", val);
    }
  
    catch (FormatException e)
    {
        Console.Write("Exception Thrown: ");
        Console.Write("{0}", e.GetType(), e.Message);
    }
  
    catch (OverflowException e) 
    {
        Console.Write("Exception Thrown: ");
        Console.Write("{0}", e.GetType(), e.Message);
    }
}
  
// Defining get() method
public static void get(string s,
           CultureInfo cultures)
{
  
    // converting string to
    // specified long value
    long val = Convert.ToInt64(s, cultures);
  
    // display the converted long value
    Console.Write(" {0}, ", val);
}
}
Producción:

Converted long value of specified strings:  12345,  12345,  -12345, 

s is less than the MinValue
Exception Thrown: System.OverflowException

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

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *