我有一个负责错误处理的课程。如果调用析构函数,我想执行一个进程。但遗憾的是,这个过程不会开始。新进程使用一些参数调用exe,它应该发送一封电子邮件。 为什么这不起作用?
~ErrorH()
{
if ((int)e > 0)
SendErrorMail();
}
private void SendErrorMail()
{
if (File.Exists("C:\\Program Files (x86)\\MailSend\\MailSend.exe"))
{
ProcessStartInfo mailsend = new ProcessStartInfo();
mailsend.FileName = "C:\\Program Files (x86)\\MailSend\\MailSend.exe";
mailsend.Arguments = "…";
Process.Start(mailsend);
}
}
如果我在构造函数中执行SendErrorMail
函数,一切正常。如果我查看调试器,似乎我到达了Process.Start(mailsend);
命令。
什么地方出了错?我怎么能解决这个问题?
修改
好的,现在我使用了IDisposable
方法。它工作正常,但确实正确使用它?
class ErrorH : IDisposable
{
private bool disposed = false;
...
public void Dispose()
{
Dispose(true);
GC.SuppressFinalize(this);
}
protected virtual void Dispose(bool desposing)
{
if(!this.disposed)
if ((int)e > 0)
SendErrorMail();
disposed = true;
}
在程序中我使用:
using (Parameter p = new Parameter(args[0]))
{
...
}
来自ErrorH
的课程Parameter
继承。
格尔茨
答案 0 :(得分:2)
使用接口System.IDisposable
而不是使用无法保证在当前时间调用的析构函数。
通常,在C#中使用析构函数是一种不好的做法,例如C ++。由于我们无法确定垃圾收集器(GC)会破坏对象的具体时间,因此C#提供了IDisposable
,它有一个方法Dispose
,您可以在完成对象使用后明确调用它,或using
阻止隐含地。