Whats wrong with your code? If some exception will occur before you close stream, then stream will stay open, and system resources will not be released:
StreamWriter sr = new StreamWriter(streamFolder);
sr.Write(details);
// some exception occurs here
File.SetAttributes(streamFolder, FileAttributes.Hidden);
sr.Close();
So, you need to be sure, that stream will be closed. This could be achieved by try...finally
block:
StreamWriter sr = new StreamWriter(streamFolder);
try
{
sr.Write(details);
// some exception occurs here
File.SetAttributes(streamFolder, FileAttributes.Hidden);
}
finally
{
sr.Close();
}
But StreamWriter implements IDisposable interface, so you can let C# compiler do it automatically for you by wrapping writer usage into using
block:
using(StreamWriter sr = new StreamWriter(streamFolder))
{
sr.Write(details);
// some exception occurs here
File.SetAttributes(streamFolder, FileAttributes.Hidden);
}
This code will be compiled as:
StreamWriter sr = new StreamWriter(streamFolder);
try
{
sr.Write(details);
// some exception occurs here
File.SetAttributes(streamFolder, FileAttributes.Hidden);
}
finally
{
if (sr != null)
sr.Dispose();
}
The only difference between manual implementation is null-check and method Dispose
is called instead of Close
. But actually when you call Close()
or Dispose()
same code will be executed:
this.Dispose(true);
GC.SuppressFinalize(this);
You can read more on Dispose method implementation.
与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…