gpt4 book ai didi

c# - 从 Azure Blob 存储读取数据时 OpenReadAsync() 出现奇怪的结果

转载 作者:行者123 更新时间:2023-12-03 03:02:24 30 4
gpt4 key购买 nike

我正在尝试修改现有的 C#(dot net core)应用程序,该应用程序读取某种类型的二进制文件以使用 Azure Blob 存储。

我正在使用 Windows.Azure.Storage (8.6.0)。

问题是这个应用程序以非常小的 block (例如 5000-6000 字节)从 Stream 的文件中读取二进制数据。这反射(reflect)了数据的结构。

伪代码示例:

var blocks = new List<byte[]>(); 
var numberOfBytesToRead = 6240;
var numberOfBlocksToRead = 1700;

using (var stream = await blob.OpenReadAsync())
{
stream.Seek(3000, SeekOrigin.Begin); // start reading at a particular position
for (int i = 1; i <= numberOfBlocksToRead; i++)
{
byte[] traceValues = new byte[numberOfBytesToRead];
stream.Read(traceValues, 0, numberOfBytesToRead);
blocks.Add(traceValues);
}
}`

如果我尝试使用 OpenReadAsync() 读取 10mb 文件,则在大约 4,190,000 字节后,我会在字节数组中收到无效/垃圾值。

  • 如果我将 StreamMinimumReadSize 设置为 100Mb,它就可以工作。
  • 如果我每个 block 读取更多数据(例如 1mb),它就会起作用。

某些文件可能超过 100Mb,因此设置 StreamMinimumReadSize 可能不是最佳解决方案。

这是怎么回事?我该如何解决这个问题?

最佳答案

无效/垃圾值是否为零?如果是这样(即使不是),请检查stream.Read 的返回值。该方法不能保证实际读取您要求的字节数。可以少读点。在这种情况下,您应该在循环中再次调用它,直到它读取您想要的总量。快速的网络搜索应该会向您展示大量必要循环的示例。

关于c# - 从 Azure Blob 存储读取数据时 OpenReadAsync() 出现奇怪的结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47636832/

30 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com