Sequential File Programming Patterns and Performance with .NET


Abstract:  Programming patterns for sequential file access in the .NET Framework are described and the performance is measured.  The default behavior provides excellent performance on a single disk – 50 MBps both reading and writing.  Using large request sizes and doing file pre-allocation when possible have quantifiable benefits.   When one considers disk arrays, .NET unbuffered IO delivers 800 MBps on a 16-disk array, but buffered IO delivers about 12% of that performance.  Consequently, high-performance file and database utilities are still forced to use unbuffered IO for maximum sequential performance.  The report is accompanied by downloadable source code that demonstrates the concepts and code that was used to obtain these measurements.




Leave a Reply

Fill in your details below or click an icon to log in: Logo

You are commenting using your account. Log Out /  Change )

Google+ photo

You are commenting using your Google+ account. Log Out /  Change )

Twitter picture

You are commenting using your Twitter account. Log Out /  Change )

Facebook photo

You are commenting using your Facebook account. Log Out /  Change )


Connecting to %s