【问题标题】:WebRequest.GetRequestStream and LOHWebRequest.GetRequestStream 和 LOH
【发布时间】:2012-10-24 15:42:08
【问题描述】:

我正在使用下面的代码将大文件上传到服务器,并注意到将 FileStream 复制到 GetRequestStream 字节数组被创建并保存在内存中。这增加了大对象堆,我不想要它。也许有人知道如何解决这个问题?

Stream formData = new FileStream(.....)

    HttpWebRequest request = WebRequest.Create(postUrl) as HttpWebRequest;
    using (Stream requestStream = request.GetRequestStream())
    {             
     Helpers.CopyStream(formData, requestStream);
     requestStream.Close();
    }

     public static void CopyStream(Stream fromStream, Stream toStream)
            {
                try
                {
                    int bytesRead;
                    byte[] buffer = new byte[32768];
                    while (fromStream != null && (bytesRead = fromStream.Read(buffer, 0, buffer.Length)) > 0)
                    {
                        toStream.Write(buffer, 0, bytesRead);
                    }
                }
                catch (IOException)
                {
                    //suppress empty stream response
                }
            }

内存分析器图表。字节数组在 GetRequestStream 内部创建

【问题讨论】:

  • 是你传递给它的字节数组,还是请求流的内部实例?
  • 字节数组和我传递的文件大小一样。

标签: c# .net webrequest


【解决方案1】:

您可以使用HttpWebRequest.AllowWriteStreamBuffering 禁用内部缓冲:

    HttpWebRequest request = WebRequest.Create(url) as HttpWebRequest;

    request.AllowWriteStreamBuffering = false;

    using (Stream formData = File.Open(fileName, FileMode.Open))
    using (Stream requestStream = request.GetRequestStream())
    {
        formData.CopyTo(requestStream, 32768);
    }

【讨论】:

  • 没有任何区别,大对象仍然存在问题。如果您查看内存分析器图表,您会发现 Bytes 数组是在复制流之后创建的。
  • 我想我找到了解决方案:HttpWebRequest.AllowWriteStreamBuffering... MSDN 说默认是 true。你可以禁用它看看会发生什么。
  • 请删除有关复制流的代码,这与问题无关,复制流时不需要刷新。经测试!
猜你喜欢
  • 2018-03-18
  • 2010-10-16
  • 1970-01-01
  • 2012-08-28
  • 2015-08-02
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2020-09-28
相关资源
最近更新 更多