I am using StreamWriter
class for file operations, are there any problems in this code that I am not seeing?
Such as do I need to put it into a try catch finally
block?
StreamWriter sr = new StreamWriter(streamFolder);
sr.Write(details);
File.SetAttributes(streamFolder, FileAttributes.Hidden);
sr.Close();
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.
You should probably use a using statement:
using (StreamWriter sr = new StreamWriter(streamFolder))
{
sr.Write(details);
File.SetAttributes(streamFolder, FileAttributes.Hidden);
}
At the end of the using block, the StreamWriter.Dispose will be called, whether there was an exception or the code ran successfully.
You want to use:
using (StreamWriter sr = new StreamWriter(streamFolder))
{
sr.Write(details);
File.SetAttributes(streamFolder, FileAttributes.Hidden);
}
You don't need the Close
.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With