С Visual Studio 2010 (возможно, и с 2008 годом) я замечаю поведение, когда Intellisense предложит полное пространство имен для перечислений.
Например, я могу написать код следующим образом:
element.HorizontalAlignment = HorizontalAlignment.Right;
element.VerticalAlignment = VerticalAlignment.Bottom;
Но когда я пытаюсь написать его, я предлагаю написать его вот так:
element.HorizontalAlignment = System.Windows.HorizontalAlignment.Right;
element.VerticalAlignment = System.Windows.VerticalAlignment.Bottom;
Этот лишний дополнительный код может действительно скомпоновать и сделать его менее читаемым, и я должен в основном бороться с Intellisense, чтобы избежать его.
Есть ли у меня причина для этого? Могу я просто отключить его? Я предполагаю, что причина в том, что имя перечисления совпадает с именем свойства. Но это действительно не очень хорошая причина.
EDIT:
Вот еще один пример, который показывает, почему полное именование не требуется.
using SomeOtherNamespace;
namespace SomeNamespace
{
public class Class1
{
public Class2 Class2 { get; set; }
public Class1()
{
// These all compile fine and none require fully qualified naming. The usage is context specific.
// Intellisense lists static and instance members and you choose what you wanted from the list.
Class2 = Class2.Default;
Class2.Name = "Name";
Class2.Name = Class2.Default.Name;
Class2 = Class2;
}
}
}
namespace SomeOtherNamespace
{
public class Class2
{
public static Class2 Default { get; set; }
// public static Class2 Class2; (This throws an error as it would create ambiguity and require fully qualified names.)
// public static string Name { get; set; } (This also throws an error because it would create ambiguity and require fully qualified names.
public string Name { get; set; }
}
}