This has been bugging me. I know Stream is an abstract class and therefore can\'t be instantiated but it has classes that are derived from it. Why is there
TextReader (which StreamReader is derived from) works with strings. Stream works with bytes. The conversion between text and bytes is performed by an Encoding.
Choose the right class based on whether the contents of your file text or binary.
It is important to understand the difference between text and bytes.
These two cases are used in different scenario
When you are using the stream class you can access the file for read and write. But when you use streamreader class you can use it to read only. This prevent the usage of file to be written. Sometimes This class is used for security purpose. e.g. for system files which are readonly.
A StreamReader is a TextReader which means it is a Stream wrapper. A TextReader will convert (or encode) Text data (string or char) to byte[] and write them down to the underlying Stream.
Looking at the difference between the two implementations, you can see that StreamReader derives from TextReader, which, as declared, deals with text instead of bytes. It seems to me as an abstraction for users who want to work with textual representation. Of course, the underlying implementation will need a Stream to consume such data, but will provide a level of abstraction for end users.