IntPtr.Subtraction(IntPtr, Int32) Оператор

Определение

Вычитает смещение из целого числа со знаком.

public:
 static IntPtr operator -(IntPtr pointer, int offset);
public static IntPtr operator - (IntPtr pointer, int offset);
static member ( - ) : nativeint * int -> nativeint
Public Shared Operator - (pointer As IntPtr, offset As Integer) As IntPtr

Параметры

pointer
IntPtr

nativeint

Целое число со знаком для вычитания смещения.

offset
Int32

Вычитаемое смещение.

Возвращаемое значение

IntPtr

nativeint

Новое целое число со знаком, которое отражает вычитание offset из pointer.

Комментарии

Метод Subtraction определяет операцию вычитания для IntPtr объектов. Он включает такой код, как показано ниже.

int[] arr = { 2, 4, 6, 8, 10, 12, 14, 16, 18, 20};
unsafe {
   fixed(int* parr = &arr[arr.GetUpperBound(0)])
   {
      IntPtr ptr = new IntPtr(parr);
      for (int ctr = 0; ctr <= arr.GetUpperBound(0); ctr++)
      {
         IntPtr newPtr = ptr - ctr * sizeof(Int32);
         Console.Write("{0}   ", Marshal.ReadInt32(newPtr));
      }
   }
}
// The example displays the following output:
//       20   18   16   14   12   10   8   6   4   2
#nowarn "9"
open System.Runtime.InteropServices
open FSharp.NativeInterop

[<EntryPoint>]
let main _ =
    let arr =
        [| 2; 4; 6; 8; 10; 12; 14; 16; 18; 20 |]

    use parr = fixed &arr[arr.GetUpperBound 0]
    
    let ptr = NativePtr.toNativeInt parr

    for i = 0 to arr.GetUpperBound 0 do
        let newPtr = ptr - nativeint i * nativeint sizeof<int>
        printf $"{Marshal.ReadInt32 newPtr}   "
    0

    // The example displays the following output:
    //       20   18   16   14   12   10   8   6   4   2
Dim arr() As Integer = {2, 4, 6, 8, 10, 12, 14, 16, 18, 20 }
Dim ptr As IntPtr = Marshal.UnsafeAddrOfPinnedArrayElement(arr, arr.GetUpperBound(0))
For ctr As Integer= 0 To arr.GetUpperBound(0)
   Dim newPtr As IntPtr = ptr - ctr * Len(arr(0))
   Console.Write("{0}   ", Marshal.ReadInt32(newPtr))
Next

Языки, не поддерживающие пользовательские операторы, могут вызывать Subtract метод.

Операция вычитания не создает исключение, если результат слишком мал для представления в виде целого числа со знаком в выполняемом процессе. Вместо этого он выполняется в неспроверяемом контексте.

В C# начиная с версии 11 и при выборе целевой среды выполнения .NET 7 или более поздней версии этот API доступен только через отражение. Оператор вычитания напрямую распознается языком и будет соответствовать нормальному поведению языка для операций вычитания, включая переполнение в checked контексте, если результат слишком мал для представления.

Эквивалентный метод для этого оператора: IntPtr.Subtract(IntPtr, Int32)

Применяется к

См. также раздел