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)