如何将整个流加载到 MemoryStream 中?

How to load entire stream into MemoryStream?(如何将整个流加载到 MemoryStream 中?)
本文介绍了如何将整个流加载到 MemoryStream 中?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

就像在主题中一样:我想将文件(从流)中的数据读取到内存(内存流)中以提高我的应用程序速度.怎么做?

Like in the topic: I want to read data from a file (from stream) into memory (memorystream) to improve my app speed. How to do it?

推荐答案

几个选项:

先将其全部读入一个字节数组...

byte[] data = File.ReadAllBytes(file);
MemoryStream stream = new MemoryStream(data);

或者使用 .NET 4 的 CopyTo 方法

MemoryStream memoryStream = new MemoryStream();
using (Stream input = File.OpenRead(file))
{
    input.CopyTo(memoryStream);
}
memoryStream.Position = 0;

或者手动操作

MemoryStream memoryStream = new MemoryStream();
using (Stream input = File.OpenRead(file))
{
    byte[] buffer = new byte[32 * 1024]; // 32K buffer for example
    int bytesRead;
    while ((bytesRead = input.Read(buffer, 0, buffer.Length)) > 0)
    {
        memoryStream.Write(buffer, 0, bytesRead);
    }
}
memoryStream.Position = 0;

这篇关于如何将整个流加载到 MemoryStream 中?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

相关文档推荐

Is Unpivot (Not Pivot) functionality available in Linq to SQL? How?(Linq to SQL 中是否提供 Unpivot(非 Pivot)功能?如何?)
How to know if a field is numeric in Linq To SQL(如何在 Linq To SQL 中知道字段是否为数字)
Linq2SQl eager load with multiple DataLoadOptions(具有多个 DataLoadOptions 的 Linq2SQl 急切加载)
Extract sql query from LINQ expressions(从 LINQ 表达式中提取 sql 查询)
LINQ Where in collection clause(LINQ Where in collection 子句)
Orderby() not ordering numbers correctly c#(Orderby() 没有正确排序数字 c#)