Int32 Структура
Определение
Важно!
Некоторые сведения относятся к предварительной версии продукта, в которую до выпуска могут быть внесены существенные изменения. Майкрософт не предоставляет никаких гарантий, явных или подразумеваемых, относительно приведенных здесь сведений.
Представляет 32-разрядное целое число со знаком.
public value class int : IComparable, IComparable<int>, IConvertible, IEquatable<int>, IFormattable
public value class int : IComparable<int>, IConvertible, IEquatable<int>, IParsable<int>, ISpanParsable<int>, IUtf8SpanParsable<int>, System::Numerics::IAdditionOperators<int, int, int>, System::Numerics::IAdditiveIdentity<int, int>, System::Numerics::IBinaryInteger<int>, System::Numerics::IBinaryNumber<int>, System::Numerics::IBitwiseOperators<int, int, int>, System::Numerics::IComparisonOperators<int, int, bool>, System::Numerics::IDecrementOperators<int>, System::Numerics::IDivisionOperators<int, int, int>, System::Numerics::IEqualityOperators<int, int, bool>, System::Numerics::IIncrementOperators<int>, System::Numerics::IMinMaxValue<int>, System::Numerics::IModulusOperators<int, int, int>, System::Numerics::IMultiplicativeIdentity<int, int>, System::Numerics::IMultiplyOperators<int, int, int>, System::Numerics::INumber<int>, System::Numerics::INumberBase<int>, System::Numerics::IShiftOperators<int, int, int>, System::Numerics::ISignedNumber<int>, System::Numerics::ISubtractionOperators<int, int, int>, System::Numerics::IUnaryNegationOperators<int, int>, System::Numerics::IUnaryPlusOperators<int, int>
public value class int : IComparable, IComparable<int>, IConvertible, IEquatable<int>, ISpanFormattable
public value class int : IComparable<int>, IConvertible, IEquatable<int>, IParsable<int>, ISpanParsable<int>, System::Numerics::IAdditionOperators<int, int, int>, System::Numerics::IAdditiveIdentity<int, int>, System::Numerics::IBinaryInteger<int>, System::Numerics::IBinaryNumber<int>, System::Numerics::IBitwiseOperators<int, int, int>, System::Numerics::IComparisonOperators<int, int, bool>, System::Numerics::IDecrementOperators<int>, System::Numerics::IDivisionOperators<int, int, int>, System::Numerics::IEqualityOperators<int, int, bool>, System::Numerics::IIncrementOperators<int>, System::Numerics::IMinMaxValue<int>, System::Numerics::IModulusOperators<int, int, int>, System::Numerics::IMultiplicativeIdentity<int, int>, System::Numerics::IMultiplyOperators<int, int, int>, System::Numerics::INumber<int>, System::Numerics::INumberBase<int>, System::Numerics::IShiftOperators<int, int, int>, System::Numerics::ISignedNumber<int>, System::Numerics::ISubtractionOperators<int, int, int>, System::Numerics::IUnaryNegationOperators<int, int>, System::Numerics::IUnaryPlusOperators<int, int>
public value class int : IComparable, IConvertible, IFormattable
public value class int : IComparable, IComparable<int>, IEquatable<int>, IFormattable
public struct Int32 : IComparable, IComparable<int>, IConvertible, IEquatable<int>, IFormattable
public readonly struct Int32 : IComparable<int>, IConvertible, IEquatable<int>, IParsable<int>, ISpanParsable<int>, IUtf8SpanParsable<int>, System.Numerics.IAdditionOperators<int,int,int>, System.Numerics.IAdditiveIdentity<int,int>, System.Numerics.IBinaryInteger<int>, System.Numerics.IBinaryNumber<int>, System.Numerics.IBitwiseOperators<int,int,int>, System.Numerics.IComparisonOperators<int,int,bool>, System.Numerics.IDecrementOperators<int>, System.Numerics.IDivisionOperators<int,int,int>, System.Numerics.IEqualityOperators<int,int,bool>, System.Numerics.IIncrementOperators<int>, System.Numerics.IMinMaxValue<int>, System.Numerics.IModulusOperators<int,int,int>, System.Numerics.IMultiplicativeIdentity<int,int>, System.Numerics.IMultiplyOperators<int,int,int>, System.Numerics.INumber<int>, System.Numerics.INumberBase<int>, System.Numerics.IShiftOperators<int,int,int>, System.Numerics.ISignedNumber<int>, System.Numerics.ISubtractionOperators<int,int,int>, System.Numerics.IUnaryNegationOperators<int,int>, System.Numerics.IUnaryPlusOperators<int,int>
public readonly struct Int32 : IComparable, IComparable<int>, IConvertible, IEquatable<int>, IFormattable
public readonly struct Int32 : IComparable, IComparable<int>, IConvertible, IEquatable<int>, ISpanFormattable
public readonly struct Int32 : IComparable<int>, IConvertible, IEquatable<int>, IParsable<int>, ISpanParsable<int>, System.Numerics.IAdditionOperators<int,int,int>, System.Numerics.IAdditiveIdentity<int,int>, System.Numerics.IBinaryInteger<int>, System.Numerics.IBinaryNumber<int>, System.Numerics.IBitwiseOperators<int,int,int>, System.Numerics.IComparisonOperators<int,int,bool>, System.Numerics.IDecrementOperators<int>, System.Numerics.IDivisionOperators<int,int,int>, System.Numerics.IEqualityOperators<int,int,bool>, System.Numerics.IIncrementOperators<int>, System.Numerics.IMinMaxValue<int>, System.Numerics.IModulusOperators<int,int,int>, System.Numerics.IMultiplicativeIdentity<int,int>, System.Numerics.IMultiplyOperators<int,int,int>, System.Numerics.INumber<int>, System.Numerics.INumberBase<int>, System.Numerics.IShiftOperators<int,int,int>, System.Numerics.ISignedNumber<int>, System.Numerics.ISubtractionOperators<int,int,int>, System.Numerics.IUnaryNegationOperators<int,int>, System.Numerics.IUnaryPlusOperators<int,int>
[System.Serializable]
public struct Int32 : IComparable, IConvertible, IFormattable
[System.Serializable]
[System.Runtime.InteropServices.ComVisible(true)]
public struct Int32 : IComparable, IComparable<int>, IConvertible, IEquatable<int>, IFormattable
public struct Int32 : IComparable, IComparable<int>, IEquatable<int>, IFormattable
type int = struct
interface IConvertible
interface IFormattable
type int = struct
interface IConvertible
interface IFormattable
interface IParsable<int>
interface ISpanFormattable
interface ISpanParsable<int>
interface IUtf8SpanFormattable
interface IUtf8SpanParsable<int>
interface IAdditionOperators<int, int, int>
interface IAdditiveIdentity<int, int>
interface IBinaryInteger<int>
interface IBinaryNumber<int>
interface IBitwiseOperators<int, int, int>
interface IComparisonOperators<int, int, bool>
interface IEqualityOperators<int, int, bool>
interface IDecrementOperators<int>
interface IDivisionOperators<int, int, int>
interface IIncrementOperators<int>
interface IModulusOperators<int, int, int>
interface IMultiplicativeIdentity<int, int>
interface IMultiplyOperators<int, int, int>
interface INumber<int>
interface INumberBase<int>
interface ISubtractionOperators<int, int, int>
interface IUnaryNegationOperators<int, int>
interface IUnaryPlusOperators<int, int>
interface IShiftOperators<int, int, int>
interface IMinMaxValue<int>
interface ISignedNumber<int>
type int = struct
interface IConvertible
interface ISpanFormattable
interface IFormattable
type int = struct
interface IConvertible
interface IFormattable
interface IParsable<int>
interface ISpanFormattable
interface ISpanParsable<int>
interface IAdditionOperators<int, int, int>
interface IAdditiveIdentity<int, int>
interface IBinaryInteger<int>
interface IBinaryNumber<int>
interface IBitwiseOperators<int, int, int>
interface IComparisonOperators<int, int, bool>
interface IEqualityOperators<int, int, bool>
interface IDecrementOperators<int>
interface IDivisionOperators<int, int, int>
interface IIncrementOperators<int>
interface IModulusOperators<int, int, int>
interface IMultiplicativeIdentity<int, int>
interface IMultiplyOperators<int, int, int>
interface INumber<int>
interface INumberBase<int>
interface ISubtractionOperators<int, int, int>
interface IUnaryNegationOperators<int, int>
interface IUnaryPlusOperators<int, int>
interface IShiftOperators<int, int, int>
interface IMinMaxValue<int>
interface ISignedNumber<int>
type int = struct
interface IConvertible
interface IFormattable
interface IParsable<int>
interface ISpanFormattable
interface ISpanParsable<int>
interface IAdditionOperators<int, int, int>
interface IAdditiveIdentity<int, int>
interface IBinaryInteger<int>
interface IBinaryNumber<int>
interface IBitwiseOperators<int, int, int>
interface IComparisonOperators<int, int, bool>
interface IEqualityOperators<int, int, bool>
interface IDecrementOperators<int>
interface IDivisionOperators<int, int, int>
interface IIncrementOperators<int>
interface IModulusOperators<int, int, int>
interface IMultiplicativeIdentity<int, int>
interface IMultiplyOperators<int, int, int>
interface INumber<int>
interface INumberBase<int>
interface ISubtractionOperators<int, int, int>
interface IUnaryNegationOperators<int, int>
interface IUnaryPlusOperators<int, int>
interface IUtf8SpanFormattable
interface IUtf8SpanParsable<int>
interface IShiftOperators<int, int, int>
interface IMinMaxValue<int>
interface ISignedNumber<int>
[<System.Serializable>]
type int = struct
interface IFormattable
interface IConvertible
[<System.Serializable>]
[<System.Runtime.InteropServices.ComVisible(true)>]
type int = struct
interface IFormattable
interface IConvertible
type int = struct
interface IFormattable
Public Structure Int32
Implements IComparable, IComparable(Of Integer), IConvertible, IEquatable(Of Integer), IFormattable
Public Structure Int32
Implements IAdditionOperators(Of Integer, Integer, Integer), IAdditiveIdentity(Of Integer, Integer), IBinaryInteger(Of Integer), IBinaryNumber(Of Integer), IBitwiseOperators(Of Integer, Integer, Integer), IComparable(Of Integer), IComparisonOperators(Of Integer, Integer, Boolean), IConvertible, IDecrementOperators(Of Integer), IDivisionOperators(Of Integer, Integer, Integer), IEqualityOperators(Of Integer, Integer, Boolean), IEquatable(Of Integer), IIncrementOperators(Of Integer), IMinMaxValue(Of Integer), IModulusOperators(Of Integer, Integer, Integer), IMultiplicativeIdentity(Of Integer, Integer), IMultiplyOperators(Of Integer, Integer, Integer), INumber(Of Integer), INumberBase(Of Integer), IParsable(Of Integer), IShiftOperators(Of Integer, Integer, Integer), ISignedNumber(Of Integer), ISpanParsable(Of Integer), ISubtractionOperators(Of Integer, Integer, Integer), IUnaryNegationOperators(Of Integer, Integer), IUnaryPlusOperators(Of Integer, Integer), IUtf8SpanParsable(Of Integer)
Public Structure Int32
Implements IComparable, IComparable(Of Integer), IConvertible, IEquatable(Of Integer), ISpanFormattable
Public Structure Int32
Implements IAdditionOperators(Of Integer, Integer, Integer), IAdditiveIdentity(Of Integer, Integer), IBinaryInteger(Of Integer), IBinaryNumber(Of Integer), IBitwiseOperators(Of Integer, Integer, Integer), IComparable(Of Integer), IComparisonOperators(Of Integer, Integer, Boolean), IConvertible, IDecrementOperators(Of Integer), IDivisionOperators(Of Integer, Integer, Integer), IEqualityOperators(Of Integer, Integer, Boolean), IEquatable(Of Integer), IIncrementOperators(Of Integer), IMinMaxValue(Of Integer), IModulusOperators(Of Integer, Integer, Integer), IMultiplicativeIdentity(Of Integer, Integer), IMultiplyOperators(Of Integer, Integer, Integer), INumber(Of Integer), INumberBase(Of Integer), IParsable(Of Integer), IShiftOperators(Of Integer, Integer, Integer), ISignedNumber(Of Integer), ISpanParsable(Of Integer), ISubtractionOperators(Of Integer, Integer, Integer), IUnaryNegationOperators(Of Integer, Integer), IUnaryPlusOperators(Of Integer, Integer)
Public Structure Int32
Implements IComparable, IConvertible, IFormattable
Public Structure Int32
Implements IComparable, IComparable(Of Integer), IEquatable(Of Integer), IFormattable
- Наследование
- Атрибуты
- Реализации
-
IComparable IComparable<Int32> IConvertible IEquatable<Int32> IFormattable IComparable<TSelf> IEquatable<TSelf> IParsable<Int32> IParsable<TSelf> ISpanFormattable ISpanParsable<Int32> ISpanParsable<TSelf> IUtf8SpanFormattable IUtf8SpanParsable<Int32> IUtf8SpanParsable<TSelf> IAdditionOperators<Int32,Int32,Int32> IAdditionOperators<TSelf,TSelf,TSelf> IAdditiveIdentity<Int32,Int32> IAdditiveIdentity<TSelf,TSelf> IBinaryInteger<Int32> IBinaryNumber<Int32> IBinaryNumber<TSelf> IBitwiseOperators<Int32,Int32,Int32> IBitwiseOperators<TSelf,TSelf,TSelf> IComparisonOperators<Int32,Int32,Boolean> IComparisonOperators<TSelf,TSelf,Boolean> IDecrementOperators<Int32> IDecrementOperators<TSelf> IDivisionOperators<Int32,Int32,Int32> IDivisionOperators<TSelf,TSelf,TSelf> IEqualityOperators<Int32,Int32,Boolean> IEqualityOperators<TSelf,TOther,TResult> IEqualityOperators<TSelf,TSelf,Boolean> IIncrementOperators<Int32> IIncrementOperators<TSelf> IMinMaxValue<Int32> IModulusOperators<Int32,Int32,Int32> IModulusOperators<TSelf,TSelf,TSelf> IMultiplicativeIdentity<Int32,Int32> IMultiplicativeIdentity<TSelf,TSelf> IMultiplyOperators<Int32,Int32,Int32> IMultiplyOperators<TSelf,TSelf,TSelf> INumber<Int32> INumber<TSelf> INumberBase<Int32> INumberBase<TSelf> IShiftOperators<Int32,Int32,Int32> IShiftOperators<TSelf,Int32,TSelf> ISignedNumber<Int32> ISubtractionOperators<Int32,Int32,Int32> ISubtractionOperators<TSelf,TSelf,TSelf> IUnaryNegationOperators<Int32,Int32> IUnaryNegationOperators<TSelf,TSelf> IUnaryPlusOperators<Int32,Int32> IUnaryPlusOperators<TSelf,TSelf>
Комментарии
Int32 — это неизменяемый тип значения, представляющий целые числа со знаком со значениями, которые варьируются от отрицательных 2 147 483 648 (который представлен Int32.MinValue константой) до положительных 2 147 483 647 (который представлен константой Int32.MaxValue ). .NET также включает 32-разрядный целочисленный тип без знака, UInt32который представляет значения, которые варьируются от 0 до 4 294 967 295.
Инициализация значения Int32
Создать экземпляр Int32 значения можно несколькими способами:
Можно объявить Int32 переменную и назначить ей литеральное целочисленное значение, которое находится в диапазоне Int32 типа данных. В следующем примере объявляется две переменные Int32 и присваивают им значения таким образом.
int number1 = 64301; int number2 = 25548612;let number1 = 64301 let number2 = 25548612Dim number1 As Integer = 64301 Dim number2 As Integer = 25548612Можно назначить значение целочисленного типа, диапазон которого является подмножеством Int32 типа. Это расширение преобразования, которое не требует оператора приведения в C# или метода преобразования в Visual Basic, но требуется один в F#.
sbyte value1 = 124; short value2 = 1618; int number1 = value1; int number2 = value2;let value1 = 124y let value2 = 1618s let number1 = int value1 let number2 = int value2Dim value1 As SByte = 124 Dim value2 As Int16 = 1618 Dim number1 As Integer = value1 Dim number2 As Integer = value2Можно присвоить значение числового типа, диапазон которого превышает диапазон типа Int32. Это сужающее преобразование, поэтому для его выполнения требуется оператор приведения в C# или F#, а также метод преобразования в Visual Basic, если
Option Strictвключен. Если числовое значение имеет Singleзначение или DoubleDecimal значение, которое включает дробный компонент, обработка его дробной части зависит от компилятора, выполняющего преобразование. В следующем примере выполняются сужающие преобразования для назначения нескольких числовых значений Int32 переменным.long lNumber = 163245617; try { int number1 = (int) lNumber; Console.WriteLine(number1); } catch (OverflowException) { Console.WriteLine($"{lNumber} is out of range of an Int32."); } double dbl2 = 35901.997; try { int number2 = (int) dbl2; Console.WriteLine(number2); } catch (OverflowException) { Console.WriteLine($"{dbl2} is out of range of an Int32."); } BigInteger bigNumber = 132451; try { int number3 = (int) bigNumber; Console.WriteLine(number3); } catch (OverflowException) { Console.WriteLine($"{bigNumber} is out of range of an Int32."); } // The example displays the following output: // 163245617 // 35902 // 132451let lNumber = 163245617L try let number1 = int lNumber printfn $"{number1}" with :? OverflowException -> printfn $"{lNumber} is out of range of an Int32." let dbl2 = 35901.997 try let number2 = int dbl2 printfn $"{number2}" with :? OverflowException -> printfn $"{dbl2} is out of range of an Int32." let bigNumber = BigInteger 132451 try let number3 = int bigNumber printfn $"{number3}" with :? OverflowException -> printfn $"{bigNumber} is out of range of an Int32." // The example displays the following output: // 163245617 // 35902 // 132451Dim lNumber As Long = 163245617 Try Dim number1 As Integer = CInt(lNumber) Console.WriteLine(number1) Catch e As OverflowException Console.WriteLine("{0} is out of range of an Int32.", lNumber) End Try Dim dbl2 As Double = 35901.997 Try Dim number2 As Integer = CInt(dbl2) Console.WriteLine(number2) Catch e As OverflowException Console.WriteLine("{0} is out of range of an Int32.", dbl2) End Try Dim bigNumber As BigInteger = 132451 Try Dim number3 As Integer = CInt(bigNumber) Console.WriteLine(number3) Catch e As OverflowException Console.WriteLine("{0} is out of range of an Int32.", bigNumber) End Try ' The example displays the following output: ' 163245617 ' 35902 ' 132451Можно вызвать метод Convert класса для преобразования любого поддерживаемого Int32 типа в значение. Это возможно, так как Int32 поддерживает интерфейс IConvertible. Следующий пример иллюстрирует преобразование массива значений Decimal в значения Int32.
decimal[] values= { Decimal.MinValue, -1034.23m, -12m, 0m, 147m, 199.55m, 9214.16m, Decimal.MaxValue }; int result; foreach (decimal value in values) { try { result = Convert.ToInt32(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("{0} is outside the range of the Int32 type.", value); } } // The example displays the following output: // -79228162514264337593543950335 is outside the range of the Int32 type. // Converted the Decimal value '-1034.23' to the Int32 value -1034. // Converted the Decimal value '-12' to the Int32 value -12. // Converted the Decimal value '0' to the Int32 value 0. // Converted the Decimal value '147' to the Int32 value 147. // Converted the Decimal value '199.55' to the Int32 value 200. // Converted the Decimal value '9214.16' to the Int32 value 9214. // 79228162514264337593543950335 is outside the range of the Int32 type.let values = [| Decimal.MinValue; -1034.23M; -12m; 0M; 147M 199.55M; 9214.16M; Decimal.MaxValue |] for value in values do try let result = Convert.ToInt32 value printfn $"Converted the {value.GetType().Name} value '{value}' to the {result.GetType().Name} value {result}." with :? OverflowException -> printfn $"{value} is outside the range of the Int32 type." // The example displays the following output: // -79228162514264337593543950335 is outside the range of the Int32 type. // Converted the Decimal value '-1034.23' to the Int32 value -1034. // Converted the Decimal value '-12' to the Int32 value -12. // Converted the Decimal value '0' to the Int32 value 0. // Converted the Decimal value '147' to the Int32 value 147. // Converted the Decimal value '199.55' to the Int32 value 200. // Converted the Decimal value '9214.16' to the Int32 value 9214. // 79228162514264337593543950335 is outside the range of the Int32 type.Dim values() As Decimal = { Decimal.MinValue, -1034.23d, -12d, 0d, 147d, _ 199.55d, 9214.16d, Decimal.MaxValue } Dim result As Integer For Each value As Decimal In values Try result = Convert.ToInt32(value) Console.WriteLine("Converted the {0} value '{1}' to the {2} value {3}.", _ value.GetType().Name, value, _ result.GetType().Name, result) Catch e As OverflowException Console.WriteLine("{0} is outside the range of the Int32 type.", _ value) End Try Next ' The example displays the following output: ' -79228162514264337593543950335 is outside the range of the Int32 type. ' Converted the Decimal value '-1034.23' to the Int32 value -1034. ' Converted the Decimal value '-12' to the Int32 value -12. ' Converted the Decimal value '0' to the Int32 value 0. ' Converted the Decimal value '147' to the Int32 value 147. ' Converted the Decimal value '199.55' to the Int32 value 200. ' Converted the Decimal value '9214.16' to the Int32 value 9214. ' 79228162514264337593543950335 is outside the range of the Int32 type.Можно вызвать метод Parse или TryParse для преобразования представления строкового значения Int32 в объект Int32. Строка может содержать десятичные или шестнадцатеричные цифры. В следующем примере показана операция синтаксического анализа с помощью десятичной и шестнадцатеричной строки.
string string1 = "244681"; try { int number1 = Int32.Parse(string1); Console.WriteLine(number1); } catch (OverflowException) { Console.WriteLine($"'{string1}' is out of range of a 32-bit integer."); } catch (FormatException) { Console.WriteLine($"The format of '{string1}' is invalid."); } string string2 = "F9A3C"; try { int number2 = Int32.Parse(string2, System.Globalization.NumberStyles.HexNumber); Console.WriteLine(number2); } catch (OverflowException) { Console.WriteLine($"'{string2}' is out of range of a 32-bit integer."); } catch (FormatException) { Console.WriteLine($"The format of '{string2}' is invalid."); } // The example displays the following output: // 244681 // 1022524let string1 = "244681" try let number1 = Int32.Parse string1 printfn $"{number1}" with | :? OverflowException -> printfn $"'{string1}' is out of range of a 32-bit integer." | :? FormatException -> printfn $"The format of '{string1}' is invalid." let string2 = "F9A3C" try let number2 = Int32.Parse(string2, System.Globalization.NumberStyles.HexNumber) printfn $"{number2}" with | :? OverflowException -> printfn $"'{string2}' is out of range of a 32-bit integer." | :? FormatException -> printfn $"The format of '{string2}' is invalid." // The example displays the following output: // 244681 // 1022524Dim string1 As String = "244681" Try Dim number1 As Integer = Int32.Parse(string1) Console.WriteLine(number1) Catch e As OverflowException Console.WriteLine("'{0}' is out of range of a 32-bit integer.", string1) Catch e As FormatException Console.WriteLine("The format of '{0}' is invalid.", string1) End Try Dim string2 As String = "F9A3C" Try Dim number2 As Integer = Int32.Parse(string2, System.Globalization.NumberStyles.HexNumber) Console.WriteLine(number2) Catch e As OverflowException Console.WriteLine("'{0}' is out of range of a 32-bit integer.", string2) Catch e As FormatException Console.WriteLine("The format of '{0}' is invalid.", string2) End Try ' The example displays the following output: ' 244681 ' 1022524
Выполнение операций со значениями Int32
Тип Int32 поддерживает стандартные математические операции, такие как добавление, вычитание, деление, умножение, отрицание и унарное отрицание. Как и другие целочисленные типы, тип Int32 также поддерживает побитовые AND, OR, XOR, операторы сдвига влево и вправо.
Стандартные числовые операторы можно использовать для сравнения двух значений Int32 или вызова метода CompareTo или Equals.
Вы также можете вызвать члены класса Math для выполнения широких числовых операций, включая получение абсолютного значения числа, вычисление кворента и остатка из целого деления, определение максимального или минимального значения двух целых чисел, получение знака числа и округление числа.
Представление int32 в виде строки
Тип Int32 обеспечивает полную поддержку стандартных и пользовательских строк числовых форматов. (Дополнительные сведения см. в разделе "Типы форматирования", "Стандартные числовые строки" и "Строки настраиваемого числового формата".)
Чтобы отформатировать значение как целочисленную Int32 строку без начальных нулей, можно вызвать метод без ToString() параметров. Используя описатель формата "D", можно также включить указанное число начальных нулей в строковое представление. Используя описатель формата N, можно включить разделители групп и указать число десятичных цифр, которые будут отображаться в строковом представлении числа. Используя описатель формата "X", можно представить Int32 значение в виде шестнадцатеричной строки. В следующем примере элементы в массиве значений Int32 форматируется четырьмя способами.
int[] numbers = { -1403, 0, 169, 1483104 };
foreach (int number in numbers)
{
// Display value using default formatting.
Console.Write("{0,-8} --> ", number.ToString());
// Display value with 3 digits and leading zeros.
Console.Write("{0,11:D3}", number);
// Display value with 1 decimal digit.
Console.Write("{0,13:N1}", number);
// Display value as hexadecimal.
Console.Write("{0,12:X2}", number);
// Display value with eight hexadecimal digits.
Console.WriteLine("{0,14:X8}", number);
}
// The example displays the following output:
// -1403 --> -1403 -1,403.0 FFFFFA85 FFFFFA85
// 0 --> 000 0.0 00 00000000
// 169 --> 169 169.0 A9 000000A9
// 1483104 --> 1483104 1,483,104.0 16A160 0016A160
let numbers = [| -1403; 0; 169; 1483104 |]
for number in numbers do
// Display value using default formatting.
printf $"{number,-8} --> "
// Display value with 3 digits and leading zeros.
printf $"{number,11:D3}"
// Display value with 1 decimal digit.
printf $"{number,13:N1}"
// Display value as hexadecimal.
printf $"{number,12:X2}"
// Display value with eight hexadecimal digits.
printfn $"{number,14:X8}"
// The example displays the following output:
// -1403 --> -1403 -1,403.0 FFFFFA85 FFFFFA85
// 0 --> 000 0.0 00 00000000
// 169 --> 169 169.0 A9 000000A9
// 1483104 --> 1483104 1,483,104.0 16A160 0016A160
Dim numbers() As Integer = { -1403, 0, 169, 1483104 }
For Each number As Integer In numbers
' Display value using default formatting.
Console.Write("{0,-8} --> ", number.ToString())
' Display value with 3 digits and leading zeros.
Console.Write("{0,11:D3}", number)
' Display value with 1 decimal digit.
Console.Write("{0,13:N1}", number)
' Display value as hexadecimal.
Console.Write("{0,12:X2}", number)
' Display value with eight hexadecimal digits.
Console.WriteLine("{0,14:X8}", number)
Next
' The example displays the following output:
' -1403 --> -1403 -1,403.0 FFFFFA85 FFFFFA85
' 0 --> 000 0.0 00 00000000
' 169 --> 169 169.0 A9 000000A9
' 1483104 --> 1483104 1,483,104.0 16A160 0016A160
Можно также отформатировать Int32 значение как двоичную, восьмеричную, десятичную или шестнадцатеричную строку, вызвав ToString(Int32, Int32) метод и указав базу в качестве второго параметра метода. В следующем примере этот метод вызывается для отображения двоичных, восьмимерных и шестнадцатеричных представлений массива целых значений.
int[] numbers = { -146, 11043, 2781913 };
Console.WriteLine("{0,8} {1,32} {2,11} {3,10}",
"Value", "Binary", "Octal", "Hex");
foreach (int number in numbers)
{
Console.WriteLine("{0,8} {1,32} {2,11} {3,10}",
number, Convert.ToString(number, 2),
Convert.ToString(number, 8),
Convert.ToString(number, 16));
}
// The example displays the following output:
// Value Binary Octal Hex
// -146 11111111111111111111111101101110 37777777556 ffffff6e
// 11043 10101100100011 25443 2b23
// 2781913 1010100111001011011001 12471331 2a72d9
let numbers = [| -146; 11043; 2781913 |]
printfn $"""{"Value",8} {"Binary",32} {"Octal",11} {"Hex",10}"""
for number in numbers do
printfn $"{number,8} {Convert.ToString(number, 2),32} {Convert.ToString(number, 8),11} {Convert.ToString(number, 16),10}"
// The example displays the following output:
// Value Binary Octal Hex
// -146 11111111111111111111111101101110 37777777556 ffffff6e
// 11043 10101100100011 25443 2b23
// 2781913 1010100111001011011001 12471331 2a72d9
Dim numbers() As Integer = { -146, 11043, 2781913 }
Console.WriteLine("{0,8} {1,32} {2,11} {3,10}", _
"Value", "Binary", "Octal", "Hex")
For Each number As Integer In numbers
Console.WriteLine("{0,8} {1,32} {2,11} {3,10}", _
number, Convert.ToString(number, 2), _
Convert.ToString(number, 8), _
Convert.ToString(number, 16))
Next
' The example displays the following output:
' Value Binary Octal Hex
' -146 11111111111111111111111101101110 37777777556 ffffff6e
' 11043 10101100100011 25443 2b23
' 2781913 1010100111001011011001 12471331 2a72d9
Работа с не десятичными 32-разрядными целыми числами
Помимо работы с отдельными целыми числами в виде десятичных значений, может потребоваться выполнять побитовые операции с целыми значениями или работать с двоичными или шестнадцатеричными представлениями целых чисел. Int32 Значения представлены в 31 битах с тридцати вторым битом, используемым в качестве бита знака. Положительные значения представлены с помощью представления знака и величины. Отрицательные значения находятся в двухкомплементарном представлении. Это важно учитывать при выполнении побитовых операций с значениями Int32 или при работе с отдельными битами. Чтобы выполнить числовые, логические или операции сравнения для двух не десятичных значений, оба значения должны использовать одно и то же представление.
Поля
| Имя | Описание |
|---|---|
| MaxValue |
Представляет наибольшее возможное значение Int32объекта. Это поле является константой. |
| MinValue |
Представляет наименьшее возможное значение Int32. Это поле является константой. |
Методы
| Имя | Описание |
|---|---|
| Abs(Int32) |
Вычисляет абсолютное значение. |
| BigMul(Int32, Int32) |
Создает полный продукт двух 32-разрядных чисел. |
| Clamp(Int32, Int32, Int32) |
Зацепляет значение к инклюзивному минимальному и максимальному значению. |
| CompareTo(Int32) |
Сравнивает этот экземпляр с указанным 32-разрядным целым числом со знаком и возвращает указание их относительных значений. |
| CompareTo(Object) |
Сравнивает этот экземпляр с указанным объектом и возвращает указание их относительных значений. |
| CopySign(Int32, Int32) |
Копирует знак значения в знак другого значения. |
| CreateChecked<TOther>(TOther) |
Создает экземпляр текущего типа из значения, вызывая исключение переполнения для всех значений, которые выходят за пределы представляющего диапазона текущего типа. |
| CreateSaturating<TOther>(TOther) |
Создает экземпляр текущего типа из значения, насыщая все значения, которые выходят за пределы представляющего диапазона текущего типа. |
| CreateTruncating<TOther>(TOther) |
Создает экземпляр текущего типа из значения, усечение всех значений, которые выходят за пределы представляющего диапазона текущего типа. |
| DivRem(Int32, Int32) |
Вычисляет цитент и оставшуюся часть двух значений. |
| Equals(Int32) |
Возвращает значение, указывающее, равен ли этот экземпляр указанному Int32 значению. |
| Equals(Object) |
Возвращает значение, указывающее, равен ли этот экземпляр указанному объекту. |
| GetHashCode() |
Возвращает хэш-код для этого экземпляра. |
| GetTypeCode() | |
| IsEvenInteger(Int32) |
Определяет, представляет ли значение даже целочисленное число. |
| IsNegative(Int32) |
Определяет, является ли значение отрицательным. |
| IsOddInteger(Int32) |
Определяет, представляет ли значение нечетное целочисленное число. |
| IsPositive(Int32) |
Определяет, является ли значение положительным. |
| IsPow2(Int32) |
Определяет, является ли значение двумя. |
| LeadingZeroCount(Int32) |
Вычисляет число начальных нулей в значении. |
| Log10(Int32) |
Представляет 32-разрядное целое число со знаком. |
| Log2(Int32) |
Вычисляет журнал 2 значения. |
| Max(Int32, Int32) |
Сравнивает два значения с вычислениями, которые больше. |
| MaxMagnitude(Int32, Int32) |
Сравнивает два значения с вычислениями, которые больше. |
| Min(Int32, Int32) |
Сравнивает два значения с вычислениями, которые меньше. |
| MinMagnitude(Int32, Int32) |
Сравнивает два значения с вычислениями, которые меньше. |
| Parse(ReadOnlySpan<Byte>, IFormatProvider) |
Анализирует диапазон символов UTF-8 в значение. |
| Parse(ReadOnlySpan<Byte>, NumberStyles, IFormatProvider) |
Анализирует диапазон символов UTF-8 в значение. |
| Parse(ReadOnlySpan<Char>, IFormatProvider) |
Анализирует диапазон символов в значение. |
| Parse(ReadOnlySpan<Char>, NumberStyles, IFormatProvider) |
Преобразует представление диапазона числа в указанном стиле и формате языка и региональных параметров в его 32-разрядное целое число со знаком. |
| Parse(String, IFormatProvider) |
Преобразует строковое представление числа в указанном формате языка и региональных параметров в его 32-разрядное целое число со знаком. |
| Parse(String, NumberStyles, IFormatProvider) |
Преобразует строковое представление числа в указанном стиле и формате языка и региональных параметров в его 32-разрядное целое число со знаком. |
| Parse(String, NumberStyles) |
Преобразует строковое представление числа в указанном стиле в 32-разрядное целое число со знаком. |
| Parse(String) |
Преобразует строковое представление числа в 32-разрядное целое число со знаком. |
| PopCount(Int32) |
Вычисляет количество битов, заданных в значении. |
| RotateLeft(Int32, Int32) |
Поворот значения влево на заданное значение. |
| RotateRight(Int32, Int32) |
Поворот значения вправо по заданному количеству. |
| Sign(Int32) |
Вычисляет знак значения. |
| ToString() |
Преобразует числовое значение этого экземпляра в эквивалентное строковое представление. |
| ToString(IFormatProvider) |
Преобразует числовое значение этого экземпляра в эквивалентное строковое представление, используя указанные сведения о формате, зависящее от языка и региональных параметров. |
| ToString(String, IFormatProvider) |
Преобразует числовое значение этого экземпляра в эквивалентное строковое представление, используя указанный формат и сведения о формате, зависящее от языка и региональных параметров. |
| ToString(String) |
Преобразует числовое значение этого экземпляра в эквивалентное строковое представление, используя указанный формат. |
| TrailingZeroCount(Int32) |
Вычисляет число конечных нулей в значении. |
| TryFormat(Span<Byte>, Int32, ReadOnlySpan<Char>, IFormatProvider) |
Пытается отформатировать значение текущего экземпляра как UTF-8 в предоставленный диапазон байтов. |
| TryFormat(Span<Char>, Int32, ReadOnlySpan<Char>, IFormatProvider) |
Пытается отформатировать значение текущего целочисленного экземпляра в предоставленный диапазон символов. |
| TryParse(ReadOnlySpan<Byte>, IFormatProvider, Int32) |
Пытается проанализировать диапазон символов UTF-8 в значение. |
| TryParse(ReadOnlySpan<Byte>, Int32) |
Пытается преобразовать диапазон символов UTF-8, содержащий строковое представление числа в 32-разрядное целое число со знаком. |
| TryParse(ReadOnlySpan<Byte>, NumberStyles, IFormatProvider, Int32) |
Пытается проанализировать диапазон символов UTF-8 в значение. |
| TryParse(ReadOnlySpan<Char>, IFormatProvider, Int32) |
Пытается проанализировать диапазон символов в значение. |
| TryParse(ReadOnlySpan<Char>, Int32) |
Преобразует представление диапазона числа в формате языка и региональных параметров в его 32-разрядное целое число со знаком. Возвращаемое значение указывает, успешно ли выполнено преобразование. |
| TryParse(ReadOnlySpan<Char>, NumberStyles, IFormatProvider, Int32) |
Преобразует представление диапазона числа в указанном стиле и формате языка и региональных параметров в его 32-разрядное целое число со знаком. Возвращаемое значение указывает, успешно ли выполнено преобразование. |
| TryParse(String, IFormatProvider, Int32) |
Пытается проанализировать строку в значение. |
| TryParse(String, Int32) |
Преобразует строковое представление числа в 32-разрядное целое число со знаком. Возвращаемое значение указывает, успешно ли выполнено преобразование. |
| TryParse(String, NumberStyles, IFormatProvider, Int32) |
Преобразует строковое представление числа в указанном стиле и формате языка и региональных параметров в его 32-разрядное целое число со знаком. Возвращаемое значение указывает, успешно ли выполнено преобразование. |
Явные реализации интерфейса
| Имя | Описание |
|---|---|
| IAdditionOperators<Int32,Int32,Int32>.Addition(Int32, Int32) |
Добавляет два значения вместе для вычисления суммы. |
| IAdditionOperators<Int32,Int32,Int32>.CheckedAddition(Int32, Int32) |
Добавляет два значения вместе для вычисления суммы. |
| IAdditiveIdentity<Int32,Int32>.AdditiveIdentity |
Возвращает аддитивное удостоверение текущего типа. |
| IBinaryInteger<Int32>.GetByteCount() |
Возвращает количество байтов, которые будут записываться в составе TryWriteLittleEndian(Span<Byte>, Int32). |
| IBinaryInteger<Int32>.GetShortestBitLength() |
Возвращает длину (в битах) в кратчайшем представлении текущего значения. |
| IBinaryInteger<Int32>.TryReadBigEndian(ReadOnlySpan<Byte>, Boolean, Int32) |
Представляет 32-разрядное целое число со знаком. |
| IBinaryInteger<Int32>.TryReadLittleEndian(ReadOnlySpan<Byte>, Boolean, Int32) |
Представляет 32-разрядное целое число со знаком. |
| IBinaryInteger<Int32>.TryWriteBigEndian(Span<Byte>, Int32) |
Пытается записать текущее значение в формате big-endian в заданный диапазон. |
| IBinaryInteger<Int32>.TryWriteLittleEndian(Span<Byte>, Int32) |
Пытается написать текущее значение в маленьком формате в заданном диапазоне. |
| IBinaryNumber<Int32>.AllBitsSet |
Возвращает экземпляр двоичного типа, в котором заданы все биты. |
| IBitwiseOperators<Int32,Int32,Int32>.BitwiseAnd(Int32, Int32) |
Вычисляет битовое и два значения. |
| IBitwiseOperators<Int32,Int32,Int32>.BitwiseOr(Int32, Int32) |
Вычисляет битовое или два значения. |
| IBitwiseOperators<Int32,Int32,Int32>.ExclusiveOr(Int32, Int32) |
Вычисляет монопольные или два значения. |
| IBitwiseOperators<Int32,Int32,Int32>.OnesComplement(Int32) |
Вычисляет представление заданного значения с дополнением. |
| IComparable.CompareTo(Object) |
Сравнивает этот экземпляр с указанным объектом и возвращает указание их относительных значений. |
| IComparisonOperators<Int32,Int32,Boolean>.GreaterThan(Int32, Int32) |
Сравнивает два значения, чтобы определить, какой из них больше. |
| IComparisonOperators<Int32,Int32,Boolean>.GreaterThanOrEqual(Int32, Int32) |
Сравнивает два значения, чтобы определить, какое значение больше или равно. |
| IComparisonOperators<Int32,Int32,Boolean>.LessThan(Int32, Int32) |
Сравнивает два значения, чтобы определить, что меньше. |
| IComparisonOperators<Int32,Int32,Boolean>.LessThanOrEqual(Int32, Int32) |
Сравнивает два значения, чтобы определить, что меньше или равно. |
| IConvertible.GetTypeCode() | |
| IConvertible.ToBoolean(IFormatProvider) |
Описание этого элемента см. в разделе ToBoolean(IFormatProvider). |
| IConvertible.ToByte(IFormatProvider) |
Описание этого элемента см. в разделе ToByte(IFormatProvider). |
| IConvertible.ToChar(IFormatProvider) |
Описание этого элемента см. в разделе ToChar(IFormatProvider). |
| IConvertible.ToDateTime(IFormatProvider) |
Это преобразование не поддерживается. Попытка использовать этот метод вызывает InvalidCastExceptionисключение. |
| IConvertible.ToDecimal(IFormatProvider) |
Описание этого элемента см. в разделе ToDecimal(IFormatProvider). |
| IConvertible.ToDouble(IFormatProvider) |
Описание этого элемента см. в разделе ToDouble(IFormatProvider). |
| IConvertible.ToInt16(IFormatProvider) |
Описание этого элемента см. в разделе ToInt16(IFormatProvider). |
| IConvertible.ToInt32(IFormatProvider) |
Описание этого элемента см. в разделе ToInt32(IFormatProvider). |
| IConvertible.ToInt64(IFormatProvider) |
Описание этого элемента см. в разделе ToInt64(IFormatProvider). |
| IConvertible.ToSByte(IFormatProvider) |
Описание этого элемента см. в разделе ToSByte(IFormatProvider). |
| IConvertible.ToSingle(IFormatProvider) |
Описание этого элемента см. в разделе ToSingle(IFormatProvider). |
| IConvertible.ToType(Type, IFormatProvider) |
Описание этого элемента см. в разделе ToType(Type, IFormatProvider). |
| IConvertible.ToUInt16(IFormatProvider) |
Описание этого элемента см. в разделе ToUInt16(IFormatProvider). |
| IConvertible.ToUInt32(IFormatProvider) |
Описание этого элемента см. в разделе ToUInt32(IFormatProvider). |
| IConvertible.ToUInt64(IFormatProvider) |
Описание этого элемента см. в разделе ToUInt64(IFormatProvider). |
| IDecrementOperators<Int32>.CheckedDecrement(Int32) |
Уменьшает значение. |
| IDecrementOperators<Int32>.Decrement(Int32) |
Уменьшает значение. |
| IDivisionOperators<Int32,Int32,Int32>.Division(Int32, Int32) |
Делит одно значение на другое, чтобы вычислить их кворот. |
| IEqualityOperators<Int32,Int32,Boolean>.Equality(Int32, Int32) |
Сравнивает два значения для определения равенства. |
| IEqualityOperators<Int32,Int32,Boolean>.Inequality(Int32, Int32) |
Сравнивает два значения для определения неравенства. |
| IIncrementOperators<Int32>.CheckedIncrement(Int32) |
Увеличивает значение. |
| IIncrementOperators<Int32>.Increment(Int32) |
Увеличивает значение. |
| IMinMaxValue<Int32>.MaxValue |
Возвращает максимальное значение текущего типа. |
| IMinMaxValue<Int32>.MinValue |
Возвращает минимальное значение текущего типа. |
| IModulusOperators<Int32,Int32,Int32>.Modulus(Int32, Int32) |
Делит два значения вместе, чтобы вычислить их модулу или оставшуюся часть. |
| IMultiplicativeIdentity<Int32,Int32>.MultiplicativeIdentity |
Возвращает умножающее удостоверение текущего типа. |
| IMultiplyOperators<Int32,Int32,Int32>.CheckedMultiply(Int32, Int32) |
Умножает два значения вместе, чтобы вычислить свой продукт. |
| IMultiplyOperators<Int32,Int32,Int32>.Multiply(Int32, Int32) |
Умножает два значения вместе, чтобы вычислить свой продукт. |
| INumber<Int32>.MaxNumber(Int32, Int32) |
Сравнивает два значения с вычислениями, которые больше и возвращают другое значение, если входные данные. |
| INumber<Int32>.MinNumber(Int32, Int32) |
Сравнивает два значения с вычислениями, которые меньше и возвращают другое значение, если входные данные имеют |
| INumberBase<Int32>.IsCanonical(Int32) |
Определяет, находится ли значение в его каноническом представлении. |
| INumberBase<Int32>.IsComplexNumber(Int32) |
Определяет, представляет ли значение сложное число. |
| INumberBase<Int32>.IsFinite(Int32) |
Определяет, является ли значение конечным. |
| INumberBase<Int32>.IsImaginaryNumber(Int32) |
Определяет, представляет ли значение чистое мнимое число. |
| INumberBase<Int32>.IsInfinity(Int32) |
Определяет, является ли значение бесконечным. |
| INumberBase<Int32>.IsInteger(Int32) |
Определяет, представляет ли значение целочисленное число. |
| INumberBase<Int32>.IsNaN(Int32) |
Определяет, является ли значение naN. |
| INumberBase<Int32>.IsNegativeInfinity(Int32) |
Определяет, является ли значение отрицательным бесконечностью. |
| INumberBase<Int32>.IsNormal(Int32) |
Определяет, является ли значение нормальным. |
| INumberBase<Int32>.IsPositiveInfinity(Int32) |
Определяет, является ли значение положительным бесконечностью. |
| INumberBase<Int32>.IsRealNumber(Int32) |
Определяет, представляет ли значение реальное число. |
| INumberBase<Int32>.IsSubnormal(Int32) |
Определяет, является ли значение ненормальным. |
| INumberBase<Int32>.IsZero(Int32) |
Определяет, равно ли значение нулю. |
| INumberBase<Int32>.MaxMagnitudeNumber(Int32, Int32) |
Сравнивает два значения с вычислениями, которые имеют большую величину и возвращают другое значение, если входные данные. |
| INumberBase<Int32>.MinMagnitudeNumber(Int32, Int32) |
Сравнивает два значения с вычислениями, которые имеют меньшую величину и возвращают другое значение, если входные данные. |
| INumberBase<Int32>.MultiplyAddEstimate(Int32, Int32, Int32) |
Вычисляет оценку ( |
| INumberBase<Int32>.One |
Возвращает значение |
| INumberBase<Int32>.Radix |
Возвращает радикс или базу для типа. |
| INumberBase<Int32>.TryConvertFromChecked<TOther>(TOther, Int32) |
Представляет 32-разрядное целое число со знаком. |
| INumberBase<Int32>.TryConvertFromSaturating<TOther>(TOther, Int32) |
Представляет 32-разрядное целое число со знаком. |
| INumberBase<Int32>.TryConvertFromTruncating<TOther>(TOther, Int32) |
Представляет 32-разрядное целое число со знаком. |
| INumberBase<Int32>.TryConvertToChecked<TOther>(Int32, TOther) |
Пытается преобразовать экземпляр текущего типа в другой тип, вызывая исключение переполнения для любых значений, которые выходят за пределы представляющего диапазона текущего типа. |
| INumberBase<Int32>.TryConvertToSaturating<TOther>(Int32, TOther) |
Пытается преобразовать экземпляр текущего типа в другой тип, насыщая все значения, которые выходят за пределы представляющего диапазона текущего типа. |
| INumberBase<Int32>.TryConvertToTruncating<TOther>(Int32, TOther) |
Пытается преобразовать экземпляр текущего типа в другой тип, усечение любых значений, которые выходят за пределы представляющего диапазона текущего типа. |
| INumberBase<Int32>.Zero |
Возвращает значение |
| IShiftOperators<Int32,Int32,Int32>.LeftShift(Int32, Int32) |
Сдвигает значение влево по заданной сумме. |
| IShiftOperators<Int32,Int32,Int32>.RightShift(Int32, Int32) |
Сдвигает значение вправо по заданной сумме. |
| IShiftOperators<Int32,Int32,Int32>.UnsignedRightShift(Int32, Int32) |
Сдвигает значение вправо по заданной сумме. |
| ISignedNumber<Int32>.NegativeOne |
Возвращает значение |
| ISubtractionOperators<Int32,Int32,Int32>.CheckedSubtraction(Int32, Int32) |
Вычитает два значения, чтобы вычислить их разницу. |
| ISubtractionOperators<Int32,Int32,Int32>.Subtraction(Int32, Int32) |
Вычитает два значения, чтобы вычислить их разницу. |
| IUnaryNegationOperators<Int32,Int32>.CheckedUnaryNegation(Int32) |
Вычисляет проверенное унарное отрицание значения. |
| IUnaryNegationOperators<Int32,Int32>.UnaryNegation(Int32) |
Вычисляет унарное отрицание значения. |
| IUnaryPlusOperators<Int32,Int32>.UnaryPlus(Int32) |
Вычисляет унарный плюс значения. |
Применяется к
Потокобезопасность
Все члены этого типа являются потокобезопасны. Элементы, которые, как представляется, изменяют состояние экземпляра, фактически возвращают новый экземпляр, инициализированный с новым значением. Как и в случае с любым другим типом, чтение и запись в общую переменную, которая содержит экземпляр этого типа, должна быть защищена блокировкой, чтобы гарантировать безопасность потока.