我使用.ToArray()方法将我的字符串转换为char数组,该数组的大小保持了char[] buffer = new char[1000000];,但当我使用以下代码时:
using (StreamReader streamReader = new StreamReader(path1))
{
buffer = streamReader.ReadToEnd().ToCharArray();
}
// buffer = result.ToArray();
threadfunc(data_path1);缓冲区的大小被固定为8190,即使它在使用.ToCharArray()或.ToArray()之后也没有读取整个文件。.ToCharArray()或.ToArray()有大小限制的原因是什么?就像我不使用这个函数一样,我能够以字符串格式读取整个文件,但是当试图通过使用这个函数将其转换为char数组时,我会受到大小限制。
发布于 2017-02-27 07:40:51
ToCharArray()返回数组的新实例。因此,您的buffer将引用新实例,即ReadToEnd返回的数据大小。
如果要保持buffer大小不变,只需向已存在的数组中添加新数组即可
char[] buffer = new char[1000000];
using (StreamReader streamReader = new StreamReader(path1))
{
var tempArray = streamReader.ReadToEnd().ToCharArray();
tempArray.CopyTo(buffer, 0);
}如果您只想使用结果数组-您不需要“预测”数组的大小-只需使用返回的数组
public char[] GetArrayFromFile(string pathToFile)
{
using (StreamReader streamReader = new StreamReader(path1))
{
var data = streamReader.ReadToEnd();
}
return data.ToCharArray();
}
var arrayFromFile = GetArrayFromFile(@"..\path.file");发布于 2017-02-27 07:45:00
我猜问题是,在调用ToCharArray()之前,从读到尾应该完成。这可能对你有帮助。您不需要定义缓冲区,因为ToCharArray()创建了char[]本身的一个新实例。
string content;
using (StreamReader streamReader = new StreamReader(path1))
{
content = streamReader.ReadToEnd();
}
var buffer = content.ToCharArray();发布于 2017-02-27 07:44:20
您可能使用了不正确的编码。默认情况下,StreamReader(字符串)使用UTF8编码:
完整的文件路径由path参数指定。此构造函数将编码初始化为UTF8Encoding,缓冲区大小初始化为1024字节。
除非您有特定的需要,否则不要预先分配缓冲区大小。
如果文件采用ASCII格式,则需要更新StreamReader构造函数:
char[] buffer = null;
using (StreamReader streamReader = new StreamReader(path1, Encoding.ASCII))
{
buffer = streamReader.ReadToEnd().ToCharArray();
}
// buffer = result.ToArray();
threadfunc(data_path1);https://stackoverflow.com/questions/42479944
复制相似问题