Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Do adding properties to an interface prevent creating private/protected "set" in derived types?

Tags:

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.

like image 764
Catskul Avatar asked Mar 10 '10 20:03

Catskul


People also ask

Can we have properties in interface?

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.

Should interfaces have properties?

Yes, An interface should define properties when it really in need.

Can we add properties in interface C#?

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)

CAN interface have protected members?

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.


2 Answers

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; }
}
like image 171
BFree Avatar answered Oct 21 '22 01:10

BFree


It's possible on interfaces, but not on abstract/virtual properties - you may have these two mixed up.

like image 41
Mark Seemann Avatar answered Oct 21 '22 00:10

Mark Seemann