I'm reading the documentation on TcpClient.Close() and noticed this:
Calling this method will eventually result in the close of the associated Socket and will also close the associated NetworkStream that is used to send and receive data if one was created.
So, correct me if I'm wrong but this says that if one calls Close()
on the TcpClient
that the NetworkStream
will also be closed.
So then why at the end of the code example are both Close()
called?
networkStream.Close();
tcpClient.Close();
Would it be just as fine to only call tcpClient.Close();
?
Responding to this question since no one else did so that I may accept an answer.
According to Hans, calling NetworkStream.Close() is unnecessary because TcpClient.Close() closes its underlying NetworkStream.
NetworkStream and TcpClient implement IDisposable. So best practise in my opinion is to pack it into a using block, so you never need to close or dispose it manually.
Closing the client does not close the stream, it's in the doc of the GetStream method.
For the reference, have a look to this discussion : How to properly and completely close/reset a TcpClient connection?
You should Just do "TcpClient.Close()"
Or if you must, type both