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.