Export (0) Print
Expand All

IntPtr.Addition Operator

Adds an offset to the value of a pointer.

Namespace:  System
Assembly:  mscorlib (in mscorlib.dll)

public static IntPtr operator +(
	IntPtr pointer,
	int offset
)

Parameters

pointer
Type: System.IntPtr
The pointer to add the offset to.
offset
Type: System.Int32
The offset to add.

Return Value

Type: System.IntPtr
A new pointer that reflects the addition of offset to pointer.

The Addition method defines the addition operation for IntPtr objects. It enables code such as the following.


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         


Languages that do not support custom operators can call the Add method instead.

The addition operation does not throw an exception if the result is too large to represent as a pointer on the specified platform. Instead, it is performed in an unchecked context.

.NET Framework

Supported in: 4

.NET Framework Client Profile

Supported in: 4

Windows 7, Windows Vista SP1 or later, Windows XP SP3, Windows Server 2008 (Server Core not supported), Windows Server 2008 R2 (Server Core supported with SP1 or later), Windows Server 2003 SP2

The .NET Framework does not support all versions of every platform. For a list of the supported versions, see .NET Framework System Requirements.

Community Additions

ADD
Show:
© 2014 Microsoft