11

我正在使用此代码将非托管代码中的 IntPtr 缓冲区中的字节保存到文件中。这是一个简单的回调函数:

private void callback(IntPtr buffer, int length)
{
    byte[] bytes = new byte[length];
    Marshal.Copy(buffer, bytes, 0, length);
    FileStream file = new FileStream(filename, FileMode.Create, FileAccess.Write);
    file.Write(bytes, 0, length);
    file.Close();
}

我想要的是将此数据存储到文件中并将其丢弃。据我了解,非托管代码中有一个缓冲区,而我的代码中有第二个缓冲区。我不想直接复制我想要的数据:

// bad:     (unmanaged) buffer -> (managed) bytes -> file
// awesome: (unmanaged) buffer ->                    file

对于我的任务,我需要最快的方式将数据存储到文件中。

4

2 回答 2

15

留在 .NET 框架内可能比使用对内核 dll 的调用更好。

我会使用:

private void callback(IntPtr buffer, int length, String filename)
{
    try
    {
        FileStream file = new FileStream(filename, FileMode.Create, FileAccess.Write);
        UnmanagedMemoryStream ustream = new UnmanagedMemoryStream((byte*)buffer, length);
        ustream.CopyTo(file);
        ustream.Close();
        file.Close();
    }
    catch{/** To do: catch code **/}
}
于 2014-05-08T05:38:00.103 回答
5

好吧,出于某种原因,它被称为“托管” :-) 您可以做的是使用P/Invoke声明WriteFile,如下所示:

private void callback(IntPtr buffer, int length)
{
    FileStream file = new FileStream(filename, FileMode.Create, FileAccess.Write);
    int written;
    WriteFile(file.Handle, buffer, length, out written, IntPtr.Zero);
    file.Close();
}

 [DllImport("kernel32.dll")]
 private static extern bool WriteFile(IntPtr hFile, IntPtr lpBuffer, int NumberOfBytesToWrite, out int lpNumberOfBytesWritten, IntPtr lpOverlapped);
于 2012-12-03T11:40:38.277 回答