I\'m setting up some demo code for a beginner session on accessibility and I found that I am able to access an internal protected property from a derived class. What am I missin
Protected
means that it is shared only with descendant classes, only private
means that it can't be accessed by anyone else.
Edit: Hans comment makes your question a little more clear. When you combine modifiers like that, they combine inclusively not exclusively. It is accesse in all the ways internal
or protected
can be.
By combining the protected and internal keywords, a class member can be marked protected internal — only derived types or types within the same assembly can access that member.
This MSDN article answers all your questions.
The protected keyword is a member access modifier. A protected member is accessible from within the class in which it is declared, and from within any class derived from the class that declared this member.
http://msdn.microsoft.com/en-us/library/bcd5672a(v=vs.71).aspx
By combining the protected and internal keywords, a class member can be marked protected internal — only derived types or types within the same assembly can access that member.
http://msdn.microsoft.com/en-us/library/ms173121(v=vs.80).aspx
Late answer but I got caught with the same issue. Eventualy I came up with a partial solution.
internal Int MyInt
{
get;
protected set;
}
It is still visible within the assembly but at least only inherithing classes can actualy change it. It is enough for what I wanted.
internal protected
means "internal to the assembly OR an inherited class". So yes, if you have a public class with an protected internal member, another class that inherits that type in a different assembly can still access it because of the protected modifier:
protected internal
The type or member can be accessed by any code in the assembly in which it is declared, or from within a derived class in another assembly. Access from another assembly must take place within a class declaration that derives from the class in which the protected internal element is declared, and it must take place through an instance of the derived class type.
Reference: http://msdn.microsoft.com/en-us/library/ms173121.aspx
This is a limitation of the C# language. The CLR supports the "Internal AND Protected" notion. There is evidence of this with the MethodAttributes.FamANDAssem enumeration if you were emitting your own IL. If you really wanted this feature, you could do some IL post processing with something like Mono.Cecil. Why the C# language does not expose this is only a guess: little need for it.
Because it's how internal protected
is intended to work. Access is given for either children in inheritance tree (protected
part) or for the same assembly (internal
part) - see Access Modifiers on MSDN.
And your ExampleClass
is in the inheritance tree of BaseClass
, which defines Prop5
. So the access is thanks to protected
part.