Edit: It turns out I missed something obvious, but I'm going to leave the question open in case someone else makes the same obvious mistake. Thanks to those who pointed it out See bottom for explanation.
Is it possible to have a non-public set on a property that is overriding an interface property?
Perhaps I'm having a stupid moment, but it seems to me that having a property defined in an interface implicily requires that no deriving class may provide any non-public set for said property.
Example:
interface IField
{
bool IsValid { get; }
}
... and since interface properties may not have accessibility modifiers means that:
class Field : IField
{
public override bool IsValid { get; protected set; }
}
...will not be possible despite the fact that it meets the interface requirements conceptually.
IMO this has large negative implications for encapsulation that might be done via non-public Properties, and prevents a number of common use patters for Propertes.
I'm aware that you can create a non-public SetIsValid member that modifies a common backing store, but that would create an inconsistent pattern and add what would otherwise be code noise were it not necessary.
Have I missed something?
Edit: Yes I have missed something
I'm modifying someone else's code at the moment and just realize that the class I was wrestling with implemented the interface and derived from a base class. And I'm new to c# That's what caused the override confusion.
the actual class looked like:
class Field : IField, BaseField
{
public override bool IsValid { get; protected set; }
}
...where BaseField implemented the interface as well, but did not implement the set.
In this articleAn interface may define a default implementation for members, including properties. Defining a default implementation for a property in an interface is rare because interfaces may not define instance data fields.
Yes, An interface should define properties when it really in need.
Interfaces can contain properties and methods, but not fields/variables. Interface members are by default abstract and public. An interface cannot contain a constructor (as it cannot be used to create objects)
Protected members of an interface In general, the protected members can be accessed in the same class or, the class inheriting it. But, we do not inherit an interface we will implement it. Therefore, the members of an interface cannot be protected.
This is perfectly legal. You don't need the override keyword (in fact it wouldn't compile) but there's nothing stopping you from doing this:
interface IField
{
bool IsValid { get; }
}
class Field : IField
{
public bool IsValid { get; protected set; }
}
It's possible on interfaces, but not on abstract/virtual properties - you may have these two mixed up.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With