Marshal.WriteIntPtr Yöntem
Tanım
Önemli
Bazı bilgiler ürünün ön sürümüyle ilgilidir ve sürüm öncesinde önemli değişiklikler yapılmış olabilir. Burada verilen bilgilerle ilgili olarak Microsoft açık veya zımni hiçbir garanti vermez.
Yönetilmeyen belleğe işlemci yerel boyutlu bir tamsayı değeri yazar. 32 bit tamsayılar 32 bit sistemlerde, 64 bit tamsayılar ise 64 bit sistemlerde yazılır. Hizalanmamış bellek konumlarına yazma desteklenir.
Aşırı Yüklemeler
WriteIntPtr(IntPtr, IntPtr) |
Yönetilmeyen belleğe işlemci yerel boyutlu bir tamsayı değeri yazar. |
WriteIntPtr(IntPtr, Int32, IntPtr) |
Belirtilen uzaklıkta yönetilmeyen belleğe işlemci yerel boyutlu bir tamsayı değeri yazar. |
WriteIntPtr(Object, Int32, IntPtr) |
Geçersiz.
Yönetilmeyen belleğe işlemci yerel boyutlu bir tamsayı değeri yazar. |
WriteIntPtr(IntPtr, IntPtr)
- Kaynak:
- Marshal.cs
- Kaynak:
- Marshal.cs
- Kaynak:
- Marshal.cs
Yönetilmeyen belleğe işlemci yerel boyutlu bir tamsayı değeri yazar.
public:
static void WriteIntPtr(IntPtr ptr, IntPtr val);
[System.Security.SecurityCritical]
public static void WriteIntPtr (IntPtr ptr, IntPtr val);
public static void WriteIntPtr (IntPtr ptr, IntPtr val);
[<System.Security.SecurityCritical>]
static member WriteIntPtr : nativeint * nativeint -> unit
static member WriteIntPtr : nativeint * nativeint -> unit
Public Shared Sub WriteIntPtr (ptr As IntPtr, val As IntPtr)
Parametreler
- ptr
-
IntPtr
nativeint
Yönetilmeyen bellekte yazacak adres.
- val
-
IntPtr
nativeint
Yazılacak değer.
- Öznitelikler
Özel durumlar
ptr
tanınan bir biçim değildir.
-veya-
ptr
, null
değeridir.
-veya-
ptr
geçersizdir.
Örnekler
Aşağıdaki örnek, ve WriteIntPtr yöntemlerini kullanarak ReadIntPtr yönetilmeyen bir diziyi nasıl okuyup yazacaklarını göstermektedir.
static void ReadWriteIntPtr()
{
// Allocate unmanaged memory.
int elementSize = Marshal.SizeOf(typeof(IntPtr));
IntPtr unmanagedArray = Marshal.AllocHGlobal(10 * elementSize);
// Set the 10 elements of the C-style unmanagedArray
for (int i = 0; i < 10; i++)
{
Marshal.WriteIntPtr(unmanagedArray, i * elementSize, ((IntPtr)(i + 1)));
}
Console.WriteLine("Unmanaged memory written.");
Console.WriteLine("Reading unmanaged memory:");
// Print the 10 elements of the C-style unmanagedArray
for (int i = 0; i < 10; i++)
{
Console.WriteLine(Marshal.ReadIntPtr(unmanagedArray, i * elementSize));
}
Marshal.FreeHGlobal(unmanagedArray);
Console.WriteLine("Done. Press Enter to continue.");
Console.ReadLine();
}
Sub ReadWriteIntPtr()
' Allocate unmanaged memory.
Dim elementSize As Integer = Marshal.SizeOf(GetType(IntPtr))
Dim unmanagedArray As IntPtr = Marshal.AllocHGlobal(10 * elementSize)
' Set the 10 elements of the C-style unmanagedArray
For i As Integer = 0 To 9
Marshal.WriteIntPtr(unmanagedArray, i * elementSize, CType(i + 1, IntPtr))
Next i
Console.WriteLine("Unmanaged memory written.")
Console.WriteLine("Reading unmanaged memory:")
' Print the 10 elements of the C-style unmanagedArray
For i As Integer = 0 To 9
Console.WriteLine(Marshal.ReadIntPtr(unmanagedArray, i * elementSize))
Next i
Marshal.FreeHGlobal(unmanagedArray)
Console.WriteLine("Done. Press Enter to continue.")
Console.ReadLine()
End Sub
Açıklamalar
WriteIntPtr yönetilmeyen bir C stili IntPtr
diziyle doğrudan etkileşime olanak sağlayarak, tüm yönetilmeyen diziyi (kullanarak Marshal.Copy) öğe değerlerini ayarlamadan önce ayrı bir yönetilen diziye kopyalamanın masrafını ortadan kaldırır.
Hizalanmamış bellek konumlarına yazma desteklenir.
Ayrıca bkz.
Şunlara uygulanır
WriteIntPtr(IntPtr, Int32, IntPtr)
- Kaynak:
- Marshal.cs
- Kaynak:
- Marshal.cs
- Kaynak:
- Marshal.cs
Belirtilen uzaklıkta yönetilmeyen belleğe işlemci yerel boyutlu bir tamsayı değeri yazar.
public:
static void WriteIntPtr(IntPtr ptr, int ofs, IntPtr val);
[System.Security.SecurityCritical]
public static void WriteIntPtr (IntPtr ptr, int ofs, IntPtr val);
public static void WriteIntPtr (IntPtr ptr, int ofs, IntPtr val);
[<System.Security.SecurityCritical>]
static member WriteIntPtr : nativeint * int * nativeint -> unit
static member WriteIntPtr : nativeint * int * nativeint -> unit
Public Shared Sub WriteIntPtr (ptr As IntPtr, ofs As Integer, val As IntPtr)
Parametreler
- ptr
-
IntPtr
nativeint
Yönetilmeyen bellekte yazacak temel adres.
- ofs
- Int32
Yazmadan önce parametresine ptr
eklenen ek bir bayt uzaklığı.
- val
-
IntPtr
nativeint
Yazılacak değer.
- Öznitelikler
Özel durumlar
Temel adres (ptr
) artı uzaklık bayt (ofs
) null veya geçersiz bir adres üretir.
Örnekler
Aşağıdaki örnek, ve WriteIntPtr yöntemlerini kullanarak ReadIntPtr yönetilmeyen bir diziyi nasıl okuyup yazacaklarını göstermektedir.
static void ReadWriteIntPtr()
{
// Allocate unmanaged memory.
int elementSize = Marshal.SizeOf(typeof(IntPtr));
IntPtr unmanagedArray = Marshal.AllocHGlobal(10 * elementSize);
// Set the 10 elements of the C-style unmanagedArray
for (int i = 0; i < 10; i++)
{
Marshal.WriteIntPtr(unmanagedArray, i * elementSize, ((IntPtr)(i + 1)));
}
Console.WriteLine("Unmanaged memory written.");
Console.WriteLine("Reading unmanaged memory:");
// Print the 10 elements of the C-style unmanagedArray
for (int i = 0; i < 10; i++)
{
Console.WriteLine(Marshal.ReadIntPtr(unmanagedArray, i * elementSize));
}
Marshal.FreeHGlobal(unmanagedArray);
Console.WriteLine("Done. Press Enter to continue.");
Console.ReadLine();
}
Sub ReadWriteIntPtr()
' Allocate unmanaged memory.
Dim elementSize As Integer = Marshal.SizeOf(GetType(IntPtr))
Dim unmanagedArray As IntPtr = Marshal.AllocHGlobal(10 * elementSize)
' Set the 10 elements of the C-style unmanagedArray
For i As Integer = 0 To 9
Marshal.WriteIntPtr(unmanagedArray, i * elementSize, CType(i + 1, IntPtr))
Next i
Console.WriteLine("Unmanaged memory written.")
Console.WriteLine("Reading unmanaged memory:")
' Print the 10 elements of the C-style unmanagedArray
For i As Integer = 0 To 9
Console.WriteLine(Marshal.ReadIntPtr(unmanagedArray, i * elementSize))
Next i
Marshal.FreeHGlobal(unmanagedArray)
Console.WriteLine("Done. Press Enter to continue.")
Console.ReadLine()
End Sub
Açıklamalar
Bu yöntem, 32 bit sistemlerde 32 bit tamsayı ve 64 bit sistemlerde 64 bit tamsayı yazar.
WriteIntPtr yönetilmeyen bir C stili IntPtr
diziyle doğrudan etkileşime olanak sağlayarak, tüm yönetilmeyen diziyi (kullanarak Marshal.Copy) öğe değerlerini ayarlamadan önce ayrı bir yönetilen diziye kopyalamanın masrafını ortadan kaldırır.
Hizalanmamış bellek konumlarına yazma desteklenir.
Ayrıca bkz.
Şunlara uygulanır
WriteIntPtr(Object, Int32, IntPtr)
- Kaynak:
- Marshal.cs
- Kaynak:
- Marshal.cs
- Kaynak:
- Marshal.cs
Dikkat
WriteIntPtr(Object, Int32, IntPtr) may be unavailable in future releases.
Yönetilmeyen belleğe işlemci yerel boyutlu bir tamsayı değeri yazar.
public:
static void WriteIntPtr(System::Object ^ ptr, int ofs, IntPtr val);
[System.Obsolete("WriteIntPtr(Object, Int32, IntPtr) may be unavailable in future releases.")]
[System.Security.SecurityCritical]
public static void WriteIntPtr (object ptr, int ofs, IntPtr val);
[System.Obsolete("WriteIntPtr(Object, Int32, IntPtr) may be unavailable in future releases.")]
public static void WriteIntPtr (object ptr, int ofs, IntPtr val);
public static void WriteIntPtr (object ptr, int ofs, IntPtr val);
[System.Security.SecurityCritical]
public static void WriteIntPtr (object ptr, int ofs, IntPtr val);
[<System.Obsolete("WriteIntPtr(Object, Int32, IntPtr) may be unavailable in future releases.")>]
[<System.Security.SecurityCritical>]
static member WriteIntPtr : obj * int * nativeint -> unit
[<System.Obsolete("WriteIntPtr(Object, Int32, IntPtr) may be unavailable in future releases.")>]
static member WriteIntPtr : obj * int * nativeint -> unit
static member WriteIntPtr : obj * int * nativeint -> unit
[<System.Security.SecurityCritical>]
static member WriteIntPtr : obj * int * nativeint -> unit
Public Shared Sub WriteIntPtr (ptr As Object, ofs As Integer, val As IntPtr)
Parametreler
- ptr
- Object
Hedef nesnenin yönetilmeyen belleğindeki temel adres.
- ofs
- Int32
Yazmadan önce parametresine ptr
eklenen ek bir bayt uzaklığı.
- val
-
IntPtr
nativeint
Yazılacak değer.
- Öznitelikler
Özel durumlar
Temel adres (ptr
) artı uzaklık bayt (ofs
) null veya geçersiz bir adres üretir.
ptr
bir ArrayWithOffset nesnedir. Bu yöntem parametreleri kabul ArrayWithOffset etmez.
Açıklamalar
WriteIntPtr yönetilmeyen bir C stili bayt dizisiyle doğrudan etkileşime olanak sağlayarak, tüm yönetilmeyen diziyi (kullanarak Marshal.Copy) öğe değerlerini ayarlamadan önce ayrı bir yönetilen diziye kopyalama masrafını ortadan kaldırır.
Hizalanmamış bellek konumlarına yazma desteklenir.
Ayrıca bkz.
Şunlara uygulanır
Geri Bildirim
https://aka.ms/ContentUserFeedback.
Çok yakında: 2024 boyunca, içerik için geri bildirim mekanizması olarak GitHub Sorunları’nı kullanımdan kaldıracak ve yeni bir geri bildirim sistemiyle değiştireceğiz. Daha fazla bilgi için bkz.Gönderin ve geri bildirimi görüntüleyin