A very similar question has also been asked here on SO in case you are interested, but as we will see the accepted answer of that question is not always the case (and it's never the case for my application use-pattern).
The performance determining code consists of FileStream constructor (to open a file) and a SHA1 hash (the .Net framework implementation). The code is pretty much C# version of what was asked in the question I've linked to above.
Case 1: The Application is started either for the first time or Nth time, but with different target file set. The application is now told to compute the hash values on the files that were never accessed before.
- ~50ms
- 80% FileStream constructor
- 18% hash computation
Case 2: Application is now fully terminated, and started again, asked to compute hash on the same files:
- ~8ms
- 90% hash computation
- 8% FileStream constructor
Problem
My application is always in use Case 1. It will never be asked to re-compute a hash on a file that was already visited once.
So my rate-determining step is FileStream Constructor! Is there anything I can do to speed up this use case?
Thank you.
P.S. Stats were gathered using JetBrains profiler.
FileStream
source, it looks like there are tons of preprocessor directives and, even in the most simple of paths, initialization appears to be pretty complex. You may want to specify which specific constructor you are having problems with and what your environment looks like and hopefully people (much) smarter than myself can help you. – HuguenotFileOptions.SequentialScan
? Have you tried enabling multicore jit viaProfileOptimization.StartProfile
? – Resentful