Share via


Leere Schnittstellen vermeiden

Aktualisiert: November 2007

     TypeName

AvoidEmptyInterfaces

CheckId

CA1040

Kategorie

Microsoft.Design

Unterbrechende Änderung

Breaking

Ursache

Von der Schnittstelle werden keine Member deklariert oder mindestens zwei weitere Schnittstellen implementiert.

Regelbeschreibung

Schnittstellen definieren Member, die ein Verhalten oder einen Verwendungsvertrag bereitstellen. Die durch die Schnittstelle beschriebene Funktionalität kann von jedem Typ übernommen werden, unabhängig davon, an welcher Stelle der Typ in der Vererbungshierarchie steht. Ein Typ implementiert eine Schnittstelle, indem er Implementierungen für die Member der Schnittstelle bereitstellt. Eine leere Schnittstelle definiert keine Member. Daher definiert sie keinen Vertrag, der implementiert werden kann.

Wenn Ihr Design leere Schnittstellen umfasst, die von Typen implementiert werden sollen, wird eine Schnittstelle wahrscheinlich als Marker oder zur Identifizierung einer Gruppe von Typen verwendet. Wenn diese Identifizierung zur Laufzeit stattfindet, müssen Sie zur richtigen Durchführung dieses Vorgangs ein benutzerdefiniertes Attribut verwenden. Überprüfen Sie, ob das Attribut bzw. dessen Eigenschaften vorhanden sind oder fehlen, um die Zieltypen zu identifizieren. Wenn die Identifikation zur Kompilierungszeit erfolgen muss, ist die Verwendung einer leeren Schnittstelle zulässig.

Behandlung von Verstößen

Entfernen Sie die Schnittstelle, oder fügen Sie der Schnittstelle Member hinzu. Wenn die leere Schnittstelle zur Bezeichnung einer Reihe von Typen verwendet wird, ersetzen Sie die Schnittstelle durch ein benutzerdefiniertes Attribut.

Wann sollten Warnungen unterdrückt werden?

Eine Warnung dieser Regel kann gefahrlos unterdrückt werden, wenn die Schnittstelle zur Kompilierungszeit dazu verwendet wird, eine Reihe von Typen zu identifizieren.

Beispiel

Im folgenden Beispiel wird eine leere Schnittstelle veranschaulicht.

Imports System     

Namespace Samples         

    Public Interface IBadInterface  ' Violates rule         
    End Interface     

End Namespace
using System;

namespace DesignLibrary
{
   public interface IBadInterface  // Violates rule
   {
   }
}
#include "stdafx.h"
using namespace System;

namespace Samples
{
    // Violates this rule
    public interface class IEmptyInterface    
    {    
    };
}