Udostępnij za pośrednictwem


Błąd kompilatora CS1614

"name" jest niejednoznaczny między "name" i "nameAttribute"; użyj polecenia "@name" lub "nameAttribute".

Kompilator napotkał niejednoznaczną specyfikację atrybutu.

Dla wygody kompilator języka C# umożliwia określenie atrybutu ExampleAttribute jako tylko [Example]. Jednak niejednoznaczność pojawia się, jeśli klasa atrybutu o nazwie Example istnieje wraz z ExampleAttribute, ponieważ kompilator nie może stwierdzić, czy [Example] odwołuje się do atrybutu Example lub atrybutu ExampleAttribute . Aby wyjaśnić, użyj atrybutu [@Example]Example i [ExampleAttribute] parametru ExampleAttribute.

Poniższy przykład generuje CS1614:

// CS1614.cs  
using System;  
  
// Both of the following classes are valid attributes with valid  
// names (MySpecial and MySpecialAttribute). However, because the lookup  
// rules for attributes involves auto-appending the 'Attribute' suffix  
// to the identifier, these two attributes become ambiguous; that is,  
// if you specify MySpecial, the compiler can't tell if you want  
// MySpecial or MySpecialAttribute.  
  
public class MySpecial : Attribute {  
   public MySpecial() {}  
}  
  
public class MySpecialAttribute : Attribute {  
   public MySpecialAttribute() {}  
}  
  
class MakeAWarning {  
   [MySpecial()] // CS1614  
                 // Ambiguous: MySpecial or MySpecialAttribute?  
   public static void Main() {  
   }  
  
   [@MySpecial()] // This isn't ambiguous, it binds to the first attribute above.  
   public static void NoWarning() {  
   }  
  
   [MySpecialAttribute()] // This isn't ambiguous, it binds to the second attribute above.  
   public static void NoWarning2() {  
   }  
  
   [@MySpecialAttribute()] // This is also legal.  
   public static void NoWarning3() {  
   }  
}