![](/img/trans.png)
[英]How to convert an SQL Server BLOB string to System.Drawing.Image?
[英]How to convert blob data to string?
我正在使用以下函数将二进制数据转换为文本:
public string BinaryToText(byte[] data)
{
MemoryStream stream = new MemoryStream(data);
StreamReader reader = new StreamReader(stream, encoding.UTF8);
string text = reader.ReadTod();
return text;
}
但是我收到 30Mb 数据的OutOfMemoryException
。
如何使用此方法或任何更好的方法解决此问题并转换大于 100Mb 的数据?
试试这个:
public string BinaryToText(byte[] data)
{
return Encoding.UTF8.GetString(data);
}
它会消耗更少的内存。 如果它仍然耗尽内存,您需要分块读取它 - 但是您如何使用数据将决定这是否可行。 你用返回的字符串做什么?
另外,我将重申我之前的问题:输入数据真的是UTF8 数据吗?
如果您可以处理作为多个字符串返回的数据,您可以执行以下操作:
public IEnumerable<string> BinaryToStrings(byte[] data, int maxStringLength)
{
var buffer = new char[maxStringLength];
using (MemoryStream stream = new MemoryStream(data))
using (StreamReader reader = new StreamReader(stream, Encoding.UTF8))
{
while (true)
{
int count = reader.Read(buffer, 0, maxStringLength);
if (count == 0)
{
break;
}
yield return new string(buffer, 0, count);
}
}
}
然后你可以像这样在 foreach 循环中调用它:
foreach (string chunk in BinaryToStrings(data, 1024))
{
// Do something with 'chunk'...
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.