wordpress   发布时间:2022-04-02  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了为什么FileStream和CopyFile比Windows资源管理器慢得多?大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

概述

我正在尝试通过网络( 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
我正在尝试通过网络( 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);
}

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

大佬总结

以上是大佬教程为你收集整理的为什么FileStream和CopyFile比Windows资源管理器慢得多?全部内容,希望文章能够帮你解决为什么FileStream和CopyFile比Windows资源管理器慢得多?所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签: