объявляется в двух разных пространствах имен и затем предпринимается попытка сделать видимыми оба пространства. Допустим, что два пространства имен содержат классMyClass.Если попытаться сделать видимыми оба пространства имен с помощью директивойsing,то имяMyClassиз первого пространства вступит в конфликт с именемMyClassиз второго пространства, обусловив появление ошибки неоднозначности. В таком случае для указания предполагаемого пространства имен явным образом можно воспользоваться
Ниже приведена общая форма оператора : :.
Здесь
Для того чтобы стало понятнее назначение описателя псевдонима пространства имен, рассмотрим следующий пример программы, в которой создаются два пространства имен,CounterиAnotherCounter,и в обоих пространствах объявляется классCountDown.Затем оба пространства имен становятся видимыми с помощью директивusing.И наконец, в методеMain() предпринимается попытка получить экземпляр объекта типаCountDown.
// Продемонстрировать необходимость описателя ::. using System;
// Использовать оба пространства имен Counter и AnotherCounter.
using Counter; using AnotherCounter;
// Объявить пространство имен для счетчиков, namespace Counter {
// Простой вычитающий счетчик, class CountDown { int val;
public CountDown(int n) { val = n;
}
// ...
}
}
// Объявить еще одно пространство имен для счетчиков, namespace AnotherCounter {
// Объявить еще один класс CountDown, принадлежащий // пространству имен AnotherCounter. class CountDown { int val;
public CountDown(int n) { val = n;
}
}
}
class WhyAliasQualifier { static void Main() { int i;
// Следующая строка, по существу, неоднозначна!
// Неясно, делается ли в ней ссылка на класс CountDown // из пространства имен Counter или AnotherCounter?
CountDown cdl = new CountDown(10); // Ошибка! ! !
//...
}
}
Если попытаться скомпилировать эту программу, то будет получено сообщение об ошибке, уведомляющее о неоднозначности в следующей строке кода из методаMain ().
CountDown cdl = new CountDown(10); // Ошибка! ! !