Ошибка: не переопределяйте объект. Вместо этого предоставьте деструктор - PullRequest
2 голосов
/ 26 августа 2009

Получение вышеуказанной ошибки в следующем коде. Как это исправить. Благодарю. Пожалуйста, посмотрите на

protected override void Finalize() {     Dispose(false); } 

в приведенном ниже коде.

using Microsoft.Win32; 
using System.Runtime.InteropServices; 

public class Kiosk : IDisposable 
{ 

    #region "IDisposable" 

    // Implementing IDisposable since it might be possible for 
    // someone to forget to cause the unhook to occur. I didn't really 
    // see any problems with this in testing, but since the SDK says 
    // you should do it, then here's a way to make sure it will happen. 

    public void Dispose() 
    { 
        Dispose(true); 
        GC.SuppressFinalize(this); 
    } 

    protected virtual void Dispose(bool disposing) 
    { 
        if (disposing) { 
        } 
        // Free other state (managed objects). 
        if (m_hookHandle != 0) { 
            UnhookWindowsHookEx(m_hookHandle); 
            m_hookHandle = 0; 
        } 
        if (m_taskManagerValue > -1) { 
            EnableTaskManager(); 
        } 
    } 

    protected override void Finalize() 
    { 
        Dispose(false); 
    } 

    #endregion 
} 

Ответы [ 3 ]

11 голосов
/ 26 августа 2009

Finalize() - это специальный метод, который нельзя переопределить в коде. Вместо этого используйте синтаксис деструктора:

~Kiosk() 
{ 
    Dispose(false); 
} 
7 голосов
/ 26 августа 2009

Делай, что говорит. Вместо:

protected override void Finalize() 
{ 
    Dispose(false); 
} 

Есть:

~Kiosk () 
{ 
    Dispose(false); 
} 
1 голос
/ 26 августа 2009

В C # следующий синтаксис компилируется в точности к тому, что вы пытаетесь выполнить.

~Kiosk()
{
    Dispose(false);
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...