2009-08-26 11 views
2

Obtenir l'erreur ci-dessus dans le code suivant. Comment le rectifier Merci. S'il vous plaît chercherErreur: ne remplace pas object.Finalize. Au lieu de cela, fournir un destructeur

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

dans le code ci-dessous.

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 
} 

Répondre

7

Faites ce qu'il dit. Au lieu de:

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

ont:

~Kiosk() 
{ 
    Dispose(false); 
} 
11

Finalize() est une méthode spéciale que vous ne pouvez pas remplacer dans le code. Utilisez la syntaxe de destructeur à la place:

~Kiosk() 
{ 
    Dispose(false); 
} 
+0

+1 pour avoir mentionné un peu pourquoi, plutôt que de simplement jeter du code. –

+1

Eh bien, il ne mentionne pas réellement pourquoi. L'exception elle-même énonce la même chose. –

1

En C#, la syntaxe suivante est compilée pour exactement ce que vous essayez d'accomplir.

~Kiosk() 
{ 
    Dispose(false); 
}