簡體   English   中英

TextReader.ReadToEnd vs Stream.CopyTo

[英]TextReader.ReadToEnd vs Stream.CopyTo

我要求連接超過500MB的文本文件。

給我的遺留代碼使用TextReader.ReadToEnd(),代碼如下:

using (TextWriter textWriter = new StreamWriter(concatenatedFile, false, fEncoding))
{
    foreach (string filename in filesToConcatenate)
    {
        using (TextReader textReader = new StreamReader(filename, Encoding.Default))
        {
            textWriter.Write(textReader.ReadToEnd());
        }
    }
}

我想更改上面的代碼以使用Stream.CopyTo()與File.OpenRead。 為了證明這種變化的合理性,我可以想到,當ReadToEnd()用於非常大的文件時,我會想到OutofMemoryException。

ReadToEnd()給我一個印象,它將讀到最后,將整個文本塊(在這種情況下,500MB ??)保存到內存中然后寫入指定的流。

所以我的問題是:在非常大的文件串聯中,Stream.CopyTo()的行為與ReadToEnd()的行為有何不同? 每次Stream.CopyTo()復制到流中時,將決定文本大小的內容是什么? 在大多數情況下,使用它而不是ReadToEnd()會阻止OutOfMemoryException嗎?

這是我想要使用的代碼:

using (Stream output = System.IO.File.OpenWrite(outputFile))
{
    foreach (string inputFile in inputFiles)
    {
        using (Stream input = System.IO.File.OpenRead(inputFile))
        {
            input.CopyTo(output);
        }
    }
}

CopyTo將以塊(4096 =默認大小)進行復制,ReadToEnd將在寫入之前讀取所有數據。 因此,使用ReadToEnd()方法將完全讀取1gb文件。 所以對於大文件,我會建議CopyTo。

CopyTo有一個重載方法來指定塊大小。

Stream.CopyTo方法(Stream,Int32) http://msdn.microsoft.com/en-us/library/dd783870.aspx

Stream.CopyTo以塊的Stream.CopyTo復制數據。 (Stream,int)重載允許您指定緩沖區的大小,但默認值為4096字節。

TextReader.ReadToEnd會將整個文件讀入內存,因此在這種情況下, Stream.CopyTo將提高內存效率。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM