以十进制或十六进制读取 2mb 二进制文件的最快方法?
Fastest way to read 2mb binary file in decimal or hex?
我正在尝试使用数据网格视图将二进制文件读入我自己的十六进制编辑器。
这是我最初的方法
FileStream RawD = new FileStream(ECUFileName, FileMode.Open, FileAccess.Read);
BinaryReader RawB = new BinaryReader(RawD);
然后我也只尝试了二进制 reader...
现在我正在使用
MemoryMappedFile RawD = MemoryMappedFile.CreateFromFile(ECUFileName);
MemoryMappedViewStream stream = RawD.CreateViewStream();
BinaryReader RawB = new BinaryReader(stream);
我想让代码做的就是读取小数并将其放入数据网格视图中。
一个 2mb 的文件需要很长时间。
while (RawB.BaseStream.Position <= RawB.BaseStream.Length)
{
if (term == true) break;
DataGridViewRow row = (DataGridViewRow)DataG.Rows[0].Clone();
DataG.Rows.Add(row);
for (int P = 0; P < I; P++)
{
if (RawB.BaseStream.Position == RawB.BaseStream.Length) break;
Int16 Byte = RawB.ReadInt16();
string ByteStr = string.Format("{0}",Byte);
DataG[P, X].Value = ByteStr;
DataG[P, X].ReadOnly = true;
string ADR = string.Format("{0:x6}", X * 10); ;
DataG.Rows[X].HeaderCell.Value = ADR;
DataG.FirstDisplayedScrollingRowIndex = DataG.FirstDisplayedScrollingRowIndex + 1;
if (term == true) break;
}
我刚刚试过了,好像快了点
byte[] bytes = File.ReadAllBytes(ECUFileName);
for (int i=0; i <= bytes.Length; i++)
{
string result = Convert.ToString(bytes[i]);
richTextBox1.AppendText(result);
}
十六进制编辑器无法用于我打算做的事情,所以我必须手动完成。
我读过很多文章,其中人们说使用文件方法读取 AllBytes,将文件存储在内存中,
当我尝试文件方法时,它也没有那么快。
我将工具箱中的 DataGridView 放到窗体上并使用了以下代码:
static void Demo(DataGridView dgv)
{
string src = @"C:\temp\currentData.txt";
var data = File.ReadAllBytes(src);
int nCols = 16; //number of columns to use in the DGV
DataTable dt = new DataTable();
for (int i = 0; i < nCols; i++)
{
dt.Columns.Add(new DataColumn { DataType = Type.GetType("System.Int16") });
}
var lastIndex = data.Length - nCols - 1;
for (int i = 0; i < lastIndex; i += nCols * 2)
{
var dr = dt.NewRow();
for (int j = 0; j <= nCols * 2 - 1; j += 2)
{
dr[j / 2] = BitConverter.ToInt16(data, i + j);
}
dt.Rows.Add(dr);
}
dgv.DataSource = dt;
}
private void Form1_Load(object sender, EventArgs e)
{
Demo(dataGridView1);
}
它在不到一秒的时间内显示了填充的 DGV。 (使用旧的 i7 920。)代码中的任何愚蠢行为(例如差一错误)是因为我从 VB.NET 手动翻译了它。事实上,如果最后一行数据不是完整的一行,它不会显示最后一行数据。我只是证明这种方式更快。另外,如果文件长度不是偶数字节,您应该进行适当的调整。
使速度更快的重要部分 是我填充了一个数据表,稍后用作 DGV 的数据源。
使用 VirtualMode 可能会更好地显示较大的文件(如 Hans Passant 所建议)。
我正在尝试使用数据网格视图将二进制文件读入我自己的十六进制编辑器。
这是我最初的方法
FileStream RawD = new FileStream(ECUFileName, FileMode.Open, FileAccess.Read);
BinaryReader RawB = new BinaryReader(RawD);
然后我也只尝试了二进制 reader...
现在我正在使用
MemoryMappedFile RawD = MemoryMappedFile.CreateFromFile(ECUFileName);
MemoryMappedViewStream stream = RawD.CreateViewStream();
BinaryReader RawB = new BinaryReader(stream);
我想让代码做的就是读取小数并将其放入数据网格视图中。 一个 2mb 的文件需要很长时间。
while (RawB.BaseStream.Position <= RawB.BaseStream.Length)
{
if (term == true) break;
DataGridViewRow row = (DataGridViewRow)DataG.Rows[0].Clone();
DataG.Rows.Add(row);
for (int P = 0; P < I; P++)
{
if (RawB.BaseStream.Position == RawB.BaseStream.Length) break;
Int16 Byte = RawB.ReadInt16();
string ByteStr = string.Format("{0}",Byte);
DataG[P, X].Value = ByteStr;
DataG[P, X].ReadOnly = true;
string ADR = string.Format("{0:x6}", X * 10); ;
DataG.Rows[X].HeaderCell.Value = ADR;
DataG.FirstDisplayedScrollingRowIndex = DataG.FirstDisplayedScrollingRowIndex + 1;
if (term == true) break;
}
我刚刚试过了,好像快了点
byte[] bytes = File.ReadAllBytes(ECUFileName);
for (int i=0; i <= bytes.Length; i++)
{
string result = Convert.ToString(bytes[i]);
richTextBox1.AppendText(result);
}
十六进制编辑器无法用于我打算做的事情,所以我必须手动完成。
我读过很多文章,其中人们说使用文件方法读取 AllBytes,将文件存储在内存中, 当我尝试文件方法时,它也没有那么快。
我将工具箱中的 DataGridView 放到窗体上并使用了以下代码:
static void Demo(DataGridView dgv)
{
string src = @"C:\temp\currentData.txt";
var data = File.ReadAllBytes(src);
int nCols = 16; //number of columns to use in the DGV
DataTable dt = new DataTable();
for (int i = 0; i < nCols; i++)
{
dt.Columns.Add(new DataColumn { DataType = Type.GetType("System.Int16") });
}
var lastIndex = data.Length - nCols - 1;
for (int i = 0; i < lastIndex; i += nCols * 2)
{
var dr = dt.NewRow();
for (int j = 0; j <= nCols * 2 - 1; j += 2)
{
dr[j / 2] = BitConverter.ToInt16(data, i + j);
}
dt.Rows.Add(dr);
}
dgv.DataSource = dt;
}
private void Form1_Load(object sender, EventArgs e)
{
Demo(dataGridView1);
}
它在不到一秒的时间内显示了填充的 DGV。 (使用旧的 i7 920。)代码中的任何愚蠢行为(例如差一错误)是因为我从 VB.NET 手动翻译了它。事实上,如果最后一行数据不是完整的一行,它不会显示最后一行数据。我只是证明这种方式更快。另外,如果文件长度不是偶数字节,您应该进行适当的调整。
使速度更快的重要部分 是我填充了一个数据表,稍后用作 DGV 的数据源。
使用 VirtualMode 可能会更好地显示较大的文件(如 Hans Passant 所建议)。