Compartilhar via


IntPtr.Addition(IntPtr, Int32) Operador

Definição

Adiciona um deslocamento a um inteiro com sinal.

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

Parâmetros

pointer
IntPtr

nativeint

O inteiro com sinal ao qual adicionar o deslocamento.

offset
Int32

O deslocamento a ser adicionado.

Retornos

IntPtr

nativeint

Um novo inteiro com sinal que reflete a adição de offset .pointer

Comentários

O Addition método define a operação de adição para IntPtr objetos. Ele habilita o código, como o seguinte.

int[] arr = {2, 4, 6, 8, 10, 12, 14, 16, 18, 20 };
unsafe {
   fixed(int* parr = arr)
   {
       IntPtr ptr = new IntPtr(parr);
       for (int ctr = 0; ctr < arr.Length; ctr++)
       {
          IntPtr newPtr = ptr + ctr * sizeof(Int32);
          Console.Write("{0}   ", Marshal.ReadInt32(newPtr));
       }
   }
}
// The example displays the following output:
//       2   4   6   8   10   12   14   16   18   20
#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

    let ptr = NativePtr.toNativeInt parr

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

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

Linguagens que não dão suporte a operadores personalizados podem chamar o método Add em vez disso.

A operação de adição não gerará uma exceção se o resultado for muito grande para representar como um inteiro com sinal no processo de execução. Em vez disso, ele é executado em um contexto desmarcado.

No C# a partir da versão 11 e ao direcionar o runtime do .NET 7 ou posterior, essa API só pode ser acessada por meio de reflexão. O operador de adição é reconhecido diretamente pelo idioma e seguirá o comportamento de linguagem normal para operações de adição, incluindo estouro em um checked contexto se o resultado for muito grande para representar.

O método equivalente para esse operador é IntPtr.Add(IntPtr, Int32)

Aplica-se a

Confira também