Attribute.Match(Object) Metodo

Definizione

Quando è sottoposto a override in una classe derivata, restituisce un valore che indica se questa istanza equivale a un oggetto specificato.

C#
public virtual bool Match (object? obj);
C#
public virtual bool Match (object obj);

Parametri

obj
Object

Un oggetto Object da confrontare con questa istanza di Attribute.

Restituisce

Boolean

true se questa istanza equivale a obj; in caso contrario, false.

Commenti

Questo metodo determina se uno Attribute è uguale a un altro. L'implementazione predefinita è uguale Equalsa , che determina se due attributi sono dello stesso tipo e hanno gli stessi valori di campo.

In generale, il metodo è destinato a eseguire un test standard per l'uguaglianza Equals di riferimento o valore. È possibile eseguire l'override del Match metodo quando si vuole eseguire un confronto personalizzato per l'uguaglianza basata su alcuni criteri diversi da quelli di due istanze di attributo sono dello stesso tipo e hanno valori identici. Ad esempio, è possibile eseguire l'override del Match metodo per confrontare gli attributi negli scenari seguenti:

  • Un attributo include un campo bit e si considerano due istanze di attributo uguali se è impostato un bit specifico. Ad esempio, un NumericDisplay attributo può includere un campo bit che indica i formati numerici (ad esempio binari, ottali, decimali ed esadecimali) supportati da un client. Il metodo sottoposto a override Match potrebbe considerare due istanze uguali se supportano lo stesso formato numerico.

  • Un attributo include più campi che contengono lo stesso tipo di informazioni oppure contiene una matrice in cui i valori possono essere in qualsiasi ordine. Ad esempio, un Author attributo può includere più campi per i nomi di autore. Il metodo sottoposto a override Match può considerare due istanze uguali se hanno gli stessi autori indipendentemente dal fatto che ogni campo sia uguale al campo corrispondente.

Esempio

Nell'esempio seguente viene illustrato l'uso di per creare un metodo di confronto personalizzato per i valori degli Match attributi. Se definisce un oggetto AuthorsAttribute che contiene internamente un List<String> oggetto che archivia i nomi degli autori. Poiché i nomi possono verificarsi in qualsiasi ordine nell'elenco, esegue l'override del Match metodo per confrontare i nomi degli autori indipendentemente dalla posizione nell'elenco. Si noti il metodo, che esegue un test per l'uguaglianza Equals dei valori, restituisce risultati diversi dal Match metodo.

C#
using System;
using System.Collections.Generic;
using System.Reflection;

// A custom attribute to allow multiple authors per method.
[AttributeUsage(AttributeTargets.Method)]
public class AuthorsAttribute : Attribute
{
   protected List<string> _authors;

    public AuthorsAttribute(params string[] names)
   {
      _authors = new List<string>(names);
    }

   public List<string> Authors
   {
       get { return _authors; }
   }

    // Determine if the object is a match to this one.
    public override bool Match(object obj)
   {
      // Return false if obj is null or not an AuthorsAttribute.
      AuthorsAttribute authors2 = obj as AuthorsAttribute;
      if (authors2 == null) return false;

        // Return true if obj and this instance are the same object reference.
      if (Object.ReferenceEquals(this, authors2))
         return true;

      // Return false if obj and this instance have different numbers of authors
      if (_authors.Count != authors2._authors.Count)
         return false;

      bool matches = false;
      foreach (var author in _authors)
      {
         for (int ctr = 0; ctr < authors2._authors.Count; ctr++)
         {
            if (author == authors2._authors[ctr])
            {
               matches = true;
               break;
            }
            if (ctr == authors2._authors.Count)
            {
               matches = false;
            }
         }
      }
      return matches;
   }

   public override string ToString()
   {
      string retval = "";
      for (int ctr = 0; ctr < _authors.Count; ctr++)
      {
         retval += $"{_authors[ctr]}{(ctr < _authors.Count - 1 ? ", " : String.Empty)}";
      }
      if (retval.Trim().Length == 0)
      {
         return "<unknown>";
      }
      return retval;
   }
}

// Add some authors to methods of a class.
public class TestClass {
    [Authors("Leo Tolstoy", "John Milton")]
    public void Method1()
    {}

    [Authors("Anonymous")]
    public void Method2()
    {}

    [Authors("Leo Tolstoy", "John Milton", "Nathaniel Hawthorne")]
    public void Method3()
    {}

    [Authors("John Milton", "Leo Tolstoy")]
    public void Method4()
    {}
}

class Example
{
    static void Main()
   {
        // Get the type for TestClass to access its metadata.
        Type clsType = typeof(TestClass);

        // Iterate through each method of the class.
      AuthorsAttribute authors = null;
        foreach(var method in clsType.GetMethods())
      {
            // Check each method for the Authors attribute.
            AuthorsAttribute authAttr = (AuthorsAttribute)  Attribute.GetCustomAttribute(method,
                                         typeof(AuthorsAttribute));
            if (authAttr != null)
         {
            // Display the authors.
                Console.WriteLine($"{clsType.Name}.{method.Name} was authored by {authAttr}.");

            // Select Method1's authors as the basis for comparison.
            if (method.Name == "Method1")
            {
                   authors = authAttr;
               Console.WriteLine();
               continue;
            }

            // Compare first authors with the authors of this method.
            if (authors.Match(authAttr))
            {
                    Console.WriteLine("TestClass.Method1 was also authored by the same team.");
            }

            // Perform an equality comparison of the two attributes.
            Console.WriteLine($"{authors} {(authors.Equals(authAttr) ? "=" : "<>")} {authAttr}");
            Console.WriteLine();
            }
        }
    }
}
// The example displays the following output:
//       TestClass.Method1 was authored by Leo Tolstoy, John Milton.
//
//       TestClass.Method2 was authored by Anonymous.
//       Leo Tolstoy, John Milton <> Anonymous
//
//       TestClass.Method3 was authored by Leo Tolstoy, John Milton, Nathaniel Hawthorne.
//       Leo Tolstoy, John Milton <> Leo Tolstoy, John Milton, Nathaniel Hawthorne
//
//       TestClass.Method4 was authored by John Milton, Leo Tolstoy.
//       TestClass.Method1 was also authored by the same team.
//       Leo Tolstoy, John Milton <> John Milton, Leo Tolstoy

Si applica a

Prodotto Versioni
.NET Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8
.NET Standard 2.0, 2.1