-8

嗨我读过这个问题:

读取非常大的文本文件,我应该合并异步吗?

我挖了网,尤其是堆栈溢出!

结果是 14 种方法可以做到这一点,但没有一个是不完整的!

在最后两天,我正在研究这个并测试和基准测试了 14 种方法。

例如 :

        private void method()
        {

        FileStream FS = new FileStream(path, FileMode.Open, FileAccess.ReadWrite);

        int FSBytes = (int) FS.Length;

        int ChunkSize = 24;

        byte[] B = new byte[ChunkSize];

        int Pos;

        for (Pos = 0; Pos < (FSBytes - ChunkSize); Pos += ChunkSize)

        {

        FS.Read(B,0 , ChunkSize);
        string content = System.Text.Encoding.Default.GetString(B);

        richTextBox1.Text=content=;


        }

        B = new byte[FSBytes - Pos];

        FS.Read(B,0, FSBytes - Pos);
        string content2 = System.Text.Encoding.Default.GetString(B);

        richTextBox1Text=content2;


        FS.Close(); 
        FS.Dispose();
        }

对于 5mb 的文本文件,它需要的时间太长,我该怎么办?

4

1 回答 1

1

这是一个读取每个流的文本文件以完成您正在尝试做的事情的工作示例。我已经用一个 100 MB 的文本文件对其进行了测试,它运行良好,但你必须看看更大的文件是否也能运行。

这就是例子。只需将 RichTextBox 带入您的表单和 VScrollBar。然后使用硬盘“C:”上的文件“test.txt”。

public partial class Form1 : Form
{
    const int PAGE_SIZE = 64;   // in characters
    int position = 0;  // position in stream

    public Form1()
    {
        InitializeComponent();
    }

    private void vScrollBar1_Scroll(object sender, ScrollEventArgs e)
    {
        position = e.NewValue * PAGE_SIZE;

        ReadFile(position);    
    }

    private void ReadFile(int position)
    {
        using (StreamReader sr = new StreamReader(@"C:\test.txt"))
        {
            char[] chars = new char[PAGE_SIZE];
            sr.BaseStream.Seek(position, SeekOrigin.Begin);
            sr.Read(chars, 0, PAGE_SIZE);

            string text = new string(chars);
            richTextBox1.Text = text;
        }    
    }

    private void Form1_Load(object sender, EventArgs e)
    {
        ReadFile(position);
    }
}
于 2013-08-08T11:30:32.803 回答