Partial 9 страница
Пример. public class List public Node(object data, Node next) { private Node first = null; // Public interface public void AddToFront(object o) {...} public void AddToBack(object o) {...} public object RemoveFromFront() {...} public object RemoveFromBack() {...} public int Count { get {...} } В этом примере объявляется частный вложенный класс Node. 10.3.8.3 Скрытие; Вложенный тип может скрывать (§3.7.1) базовый член. В объявлениях вложенных типов разрешен модификатор new, так что скрытие можно выразить явно. Пример. using System; class Base class Derived: Base class Test показан вложенный класс M, скрывающий метод M, определенный в Base. This Вложенный тип и его тип-контейнер не имеют особого отношения к доступу_this (§7.6.7). В частности, this внутри вложенного типа нельзя использовать для ссылки на члены экземпляра типа-контейнера. В случае, если вложенному типу требуется доступ к членам экземпляра типа-контейнера, доступ может быть выполнен предоставлением this для экземпляра типа-контейнера в качестве аргумента конструктора для вложенного типа. Пример. using System; class C public void F() { public class Nested public Nested(C c) { public void G() { class Test В этом примере показан этот способ. Экземпляр C создает экземпляр Nested и передает свой собственный this конструктору Nested, чтобы предоставить последовательный доступ к членам экземпляра C. 10.3.8.5 Доступ к частным и защищенным членам типа-контейнера Вложенный тип имеет доступ ко всем членам, к которым есть доступ из типа-контейнера, в том числе к членам типа-контейнера с объявленной доступностью private и protected. Пример. using System; class C public class Nested class Test показан класс C, содержащий вложенный класс Nested. Внутри Nested метод G вызывает статический метод F, определенный в C, а F имеет частную объявленную доступность. Вложенный тип может также иметь доступ к защищенным членам, определенным в базовом типе его типа-контейнера. Пример. using System; class Base class Derived: Base class Test вложенный класс Derived.Nested обращается к защищенному методу F, определенному в Base, базовом классе класса Derived, вызовом через экземпляр класса Derived. 10.3.8.6 Вложенные типы в универсальных классах Объявление универсального типа может содержать объявления вложенных типов. Параметры типа включающего класса можно использовать внутри вложенных типов. Объявление вложенного типа может содержать дополнительные параметры типа, применяемые только ко вложенному типу. Каждое объявление типа, содержащееся внутри объявления универсального типа, неявно является объявлением универсального типа. При записи обращения к типу, вложенному в универсальный тип, сформированный тип-контейнер, включая его аргументы типа, должен быть именован. Однако изнутри внешнего класса вложенный тип можно использовать без уточнения; тип экземпляра внешнего класса может быть неявно использован при формировании вложенного типа. В следующем примере показаны три разных правильных способа обращения к сформированному типу, созданному из Inner; первые два способа эквивалентны. class Outer<T> static void F(T t) { Outer<int>.Inner<string>.F(3, "abc"); // This type is different Outer.Inner<string>.F(t, "abc"); // Error, Outer needs type arg Хотя это плохой стиль программирования, параметр типа во вложенном типе может скрывать член или параметр типа, объявленный во внешнем типе: class Outer<T> 10.3.9 Зарезервированные имена членов Для упрощения реализации среды выполнения базового C# для каждого объявления исходного члена, являющегося свойством, событием или индексатором, в реализации должны быть зарезервированы две сигнатуры методов на основе вида объявления члена, его имени и типа. Объявление в программе члена, сигнатура которого совпадает с одной из этих зарезервированных сигнатур, даже если базовая реализация среды выполнения не использует эти резервирования, является ошибкой времени компиляции. Зарезервированные имена не вводят объявления, и таким образом не участвуют в поиске членов. Но подписи зарезервированного метода, связанные с объявлением, все же участвуют в наследовании (§10.3.3) и могут быть скрыты с помощью модификатора new (§10.3.4). Резервирование этих имен служит трем целям: · разрешить базовой реализации использовать обычный идентификатор в качестве имени метода для получения или установки доступа к средствам языка C#; · разрешить другим языкам возможность взаимодействия, используя обычный идентификатор в качестве имени метода для получения или установки доступа к средствам языка C#; · обеспечение того, чтобы исходный код, принятый одним соответствующим компилятором, был принят и другим, сделав особенности зарезервированных имен членов согласованными по всем реализациям C#. Объявление деструктора (§10.13) также вызывает резервирование подписи (§10.3.9.4). 10.3.9.1 Имена членов, зарезервированные для свойств Для свойства P (§10.7) типа T зарезервированы следующие подписи: T get_P(); Зарезервированы обе сигнатуры, даже если свойство доступно только для чтения или только для записи. Пример. using System; class A class B: A new public void set_P(int value) { class Test класс A определяет свойство P только для чтения, резервируя тем самым подписи для методов get_P и set_P. Класс B является производным от A, и скрывает обе эти зарезервированные сигнатуры. Далее показан вывод для вышеуказанного примера. 123 10.3.9.2 Имена членов, зарезервированные для событий Для события E (§10.8) типа делегата T зарезервированы следующие подписи:
|