[class.access.general] (original) (raw)
11 Classes [class]
11.9 Member access control [class.access]
11.9.1 General [class.access.general]
A member of a class can be
- private; that is, its name can be used only by members and friends of the class in which it is declared.
- protected; that is, its name can be used only by members and friends of the class in which it is declared, by classes derived from that class, and by their friends (see [class.protected]).
- public; that is, its name can be used anywhere without access restriction.
A member of a class can also access all the names to which the class has access.
A local class of a member function may access the same names that the member function itself may access.115
Members of a class defined with the keywordclassareprivateby default.
Members of a class defined with the keywordsstruct or unionare public by default.
[Example 1: class X { int a; };struct S { int a; }; — _end example_]
Access control is applied uniformly to all names, whether the names are referred to from declarations or expressions.
In the case of overloaded function names, access control is applied to the function selected by overload resolution.
[Note 2:
Because access control applies to names, if access control is applied to a typedef name, only the accessibility of the typedef name itself is considered.
The accessibility of the entity referred to by the typedef is not considered.
For example,
class A { class B { };public: typedef B BB;};void f() { A::BB x; A::B y; } — _end note_]
[Note 3:
Access to members and base classes is controlled, not their visibility ([basic.scope.hiding]).
Names of members are still visible, and implicit conversions to base classes are still considered, when those members and base classes are inaccessible.
— _end note_]
The interpretation of a given construct is established without regard to access control.
If the interpretation established makes use of inaccessible member names or base classes, the construct is ill-formed.
All access controls in [class.access] affect the ability to access a class member name from the declaration of a particular entity, including parts of the declaration preceding the name of the entity being declared and, if the entity is a class, the definitions of members of the class appearing outside the class's member-specification.
[Note 4:
This access also applies to implicit references to constructors, conversion functions, and destructors.
— _end note_]
[Example 2: class A { typedef int I; I f();friend I g(I);static I x;template<int> struct Q;template<int> friend struct R;protected: struct B { };}; A::I A::f() { return 0; }A::I g(A::I p = A::x); A::I g(A::I p) { return 0; }A::I A::x = 0;template<A::I> struct A::Q { };template<A::I> struct R { };struct D: A::B, A { };
Here, all the uses ofA::Iare well-formed becauseA::f,A::x, and A::Qare members of classAandgand R are friends of classA.
This implies, for example, that access checking on the first use ofA::Imust be deferred until it is determined that this use ofA::Iis as the return type of a member of classA.
Similarly, the use of A::B as abase-specifier is well-formed because Dis derived from A, so checking of base-specifier_s_must be deferred until the entire base-specifier-list has been seen.
— _end example_]
The names in a default argument ([dcl.fct.default]) are bound at the point of declaration, and access is checked at that point rather than at any points of use of the default argument.
Access checking for default arguments in function templates and in member functions of class templates is performed as described in [temp.inst].
[Example 3: class B { };template <class T> class C { protected: typedef T TT;};template <class U, class V = typename U::TT> class D : public U { }; D <C<B> >* d; — _end example_]