加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > Windows > 正文

为什么FileStream和CopyFile比Windows资源管理器慢得多?

发布时间:2020-12-14 03:59:00 所属栏目:Windows 来源:网络整理
导读:我正在尝试通过网络( Windows Server 2008 R2到Windows 7 SP1 Enterprise)复制文件,当我使用Windows资源管理器拖放时,我的速度大约为4.5 MB / s. (这是一个WAN连接) 但是,当我使用FileStream.Read()时,我只能达到1.5 MB / s左右.我尝试过不同的缓冲区大小,范
我正在尝试通过网络( Windows Server 2008 R2到Windows 7 SP1 Enterprise)复制文件,当我使用Windows资源管理器拖放时,我的速度大约为4.5 MB / s. (这是一个WAN连接)

但是,当我使用FileStream.Read()时,我只能达到1.5 MB / s左右.我尝试过不同的缓冲区大小,范围从1 KB到4 MB.我也尝试过使用CopyFile()和CopyFileEx(),但我得到了相同的结果.

可能会发生什么,我该如何修复我的代码?

编辑:我也尝试使用TeraCopy(第三方工具),它也只有1.5 MB / s.

解决方法

我不知道你是否还在经历这个问题,但我已经和这个问题搏斗了好几天,所以我想我会发布这个.我终于找到了一个与Explorer复制例程相当的解决方案.我不知道这是否适用于FileStream,但我能够使用CopyFile或CopyFileEx来获得相同的性能.就我而言,CopyFileEx是一个更好的选择,因为我想要一个进度回调.在使用Process Monitor检查复制过程之后,我注意到系统在每个32k块复制的每次读写操作之前重置了流的位置(即使它没有移动)(因此性能很差).在任何一种情况下,密钥都是在开始复制操作之前使用FileIOPermission在源文件和目标文件上设置IO权限.

以下是我的代码中的相关摘录:

new FileIOPermission(FileIOPermissionAccess.Read,SourcePath).Demand();
new FileIOPermission(FileIOPermissionAccess.Write,DestinationPath).Demand();

if (!NativeCopy.CopyFileEx(SourcePath,DestinationPath,new NativeCopy.CopyProgressRoutine(this.CopyProgressHandler),GCHandle.ToIntPtr(hArgs),ref pbCancel,flags))
{
    throw new IOException(new System.ComponentModel.Win32Exception().Message);
}

希望这会有所帮助.它让我疯狂地想弄清楚发生了什么.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读