【发布时间】:2015-05-08 03:51:25
【问题描述】:
.NET 框架中是否有任何类提供对 \.\G: - 样式路径的访问。 (即原始卷)?
我们目前使用 p/invoked ReadFile 和 WriteFile 没有任何问题,这对于同步访问并不复杂,但是添加异步读/写很乏味,因为您需要接管固定和处理 OVERLAPPED 结构和管理事件对象的生命周期等(即我们必须在 Win32 代码中做的所有繁琐的事情......)
使用任何简单的测试技术都很难证明您与 GC 的交互也是正确的。
毫无疑问,FileStream 类包含所有这些代码,以一种完全防弹和精致的方式,并利用了许多我们无法使用的内部帮助程序。不幸的是,FileStream 明确阻止您打开原始卷,因此我们无法使用它。
框架中还有什么其他东西可以帮助避免从头开始编写这种代码吗?我已经在参考源中戳了一下,但没有跳出来。
更新 - 我们已经尝试了以下建议,以避免通过自己打开设备并传入句柄来检查路径类型。当我们尝试这样做时,它会出现以下错误(请注意,此跟踪通过 FileStream 的构造函数 - 即我们根本没有任何机会与流交互): p>
System.IO.IOException: The parameter is incorrect.
at System.IO.__Error.WinIOError(Int32 errorCode, String maybeFullPath)
at System.IO.FileStream.SeekCore(Int64 offset, SeekOrigin origin)
at System.IO.FileStream..ctor(SafeFileHandle handle, FileAccess access, Int32 bufferSize, Boolean isAsync)
at OurApp.USBComms.UsbDevice..ctor(Char driveLetter) in
作为参考,我们的 CreateFile 调用如下所示:
var deviceName = String.Format(@"\\.\{0}:", driveLetter);
var handle = SafeNativeMethods.CreateFile(deviceName,
0x80000000 | 0x40000000,
FileShare.ReadWrite,
0,
FileMode.Open,
(uint)FileOptions.Asynchronous | 0x20000000, // Last option is 'FILE_FLAG_NO_BUFFERING'
IntPtr.Zero);
if (handle.IsInvalid)
{
throw new IOException("CreateFile Error: " + Marshal.GetLastWin32Error());
}
Update3:事实证明(无论如何,在卷句柄上),您不能在已使用 FILE_FLAG_OVERLAPPED 打开的句柄上调用 SetFilePointer。这是有道理的,因为 SetFilePointer 在无论如何都存在任何类型的多线程访问的文件上是无用的。不幸的是,FileStream 似乎出于某种原因(仍在试图追查原因)决定在构建期间调用它,这就是导致失败的原因。
【问题讨论】:
-
让我休息一下!这种问题现在在 SO 上是否离题?我穿过镜子了吗?
-
我不认为这是题外话。也许亲近的选民对此感到困惑框架中还有什么其他东西可以帮助避免从头开始编写这种代码吗?
-
@WillDean 这正是 SO 注定失败的原因。这里的人现在是机器人。你不能在一个问题中说“嗨”,或者在不发布一堆代码的情况下提出一些问题,而不会被否决。悲伤,但真实:/
-
我知道这是主题:-)。从 2008 年 8 月到现在,我已经掌握了 SO 的一般概念......
-
也许您应该考虑通过 kernel32 使用 IOCP 进行异步调用,而不是切换到托管代码 github.com/cloudfoundry-incubator/if_warden/blob/…
标签: c# .net filesystems