我认为我理解使用IntPtr,尽管我真的不确定.
我从MSDN复制了IDisposable模式,只是为了看看我能从中得到什么,虽然我在很大程度上了解它,但我不知道如何正确地实现IntPtr,或者甚至理解它应该是“点” “到或参考.最重要的是,我不知道如何将一个整数,字符串,char,double等分配给一个IntPtr,以创建一个指针.
此外,IntPtr是否需要不安全的代码使用?
namespace Utilities { class Disposer : IDisposable { private IntPtr handle; private Component component = new Component(); private bool disposed = false; public Disposer(IntPtr handle) { this.handle = handle; } public void Dispose() { Dispose(true); GC.SuppressFinalize(this); } protected virtual void Dispose(bool disposing) { if(!this.disposed) { if (disposing) { component.Dispose(); } CloseHandle(handle); handle = IntPtr.Zero; disposed = true; } } [System.Runtime.InteropServices.DllImport("Kernal32")] private extern static Boolean CloseHandle(IntPtr handle); } public unsafe class ExecuteMain { Object nuller = new Object(); byte boa = 0; byte *blargh = boa; public static void Main() { } } }
另外,有人可以告诉我这里的组件是什么,是吗?我也围绕这个概念缠绕我的头脑.
解决方法
你可以这样使用IntPtr对象:
int test = 55; // Allocating memory for int IntPtr intPointer = Marshal.AllocHGlobal(sizeof(int)); Marshal.WriteInt32(intPointer,test); // sending intPointer to unmanaged code here //Test reading of IntPtr object int test2 = Marshal.ReadInt32(intPointer); // test2 would be equal 55 // Free memory Marshal.FreeHGlobal(intPointer);
您可以探索其他Marshal
方法来了解如何将字符串,双精度等写入IntPtr.
所以关于你的示例代码 – 这不是一个好主意来处理外部分配的非托管对象.您应该只处理您在类构造函数中分配的对象.这不是严格的规则,而是某种好的做法.