The only thing you I don't think you can do is make the explicit implementation also a protected internal (although this doesn't make much sense anyways since you are exposing it through a public interface). YOu can still reimplement the interface without issue.
public interface IFoo { void Bar(); } class FooBase :IFoo { void IFoo.Bar() { Console.WriteLine("FooBase"); } } class FooDerived : FooBase, IFoo { void IFoo.Bar() { Console.WriteLine("FooDerived"); } } On 7/7/06, Mike Andrews <[EMAIL PROTECTED]> wrote:
Thank you. However, that does not help with the idea that a base class implements an interface and then I re-implement the interface on derived classes where needed. This is so that ever class that inherits from the base class also implements the interface, even if I do not re-implement it for the derived class. But some derived classes will add their own functionality. Thanks, Mike On 7/7/06, gregory young <[EMAIL PROTECTED]> wrote: > > You have to do whats called "explicitly implementing" a interface. See > http://msdn2.microsoft.com/en-us/library/4taxa8t2.aspx > > Cheers, > > Greg > > > On 7/7/06, Mike Andrews <[EMAIL PROTECTED]> wrote: > > > > Guys, > > > > I have a question that I need some help with in regards to implementing > an > > interface. > > I've been a VB programmer for most of my career and now I use C#. Some > of > > the functionality that I used in VB seems to be lacking in C#. > > I wanted to know if it's my imagination or if there's a workaround. > > > > The base problem is that I want to change the access level on interface > > methods once they are implemented in a class. However, C# seems to cry > > and > > such changes and VB seems to allow them. Here's the example: > > > > Here's the VB example: > > > > Public Interface IBusiness > > > > Sub Remove() > > Sub Save() > > Property ID() As Guid > > > > End Interface > > > > Public MustInherit Class T > > Implements IBusiness > > > > Public MustOverride Sub DoStuff() > > > > Protected Friend Overridable Property ID() As System.GuidImplements > > IBusiness.ID > > Get > > > > End Get > > Set(ByVal value As System.Guid) > > > > End Set > > End Property > > > > Protected Friend Overridable Sub Remove() Implements IBusiness.Remove > > > > End Sub > > > > Protected Friend Overridable Sub Save() Implements IBusiness.Save > > > > End Sub > > > > End Class > > > > Notice in this example that these methods are the implementation for > > IBusiness, but I changed the access modifiers to Protected Friend > instead > > of > > public or something else. > > > > Now, in C#, if I try to do the same, I get a compiler error: > > > > public interface IBusiness { > > > > void Remove(); > > void Save(); > > Guid ID { get; set;} > > > > } > > > > public abstract class T: IBusiness { > > > > > > #region IBusiness Members > > > > public void Remove() { > > throw new Exception("The method or operation is not > > implemented."); > > } > > > > public void Save() { > > throw new Exception("The method or operation is not > > implemented."); > > } > > > > public Guid ID { > > get { > > throw new Exception("The method or operation is not > > implemented."); > > } > > set { > > throw new Exception("The method or operation is not > > implemented."); > > } > > } > > > > #endregion > > > > } > > > > If I change the public members to protected or private I get an > error. If > > I > > change them to explicit implementation, then I cannot access them > > regardless > > unless I cast to the interface. > > > > What I'm want to do is implement an interface in a base class (so that I > > don't have to implement it in every derived class) and then > "re-implement" > > for the derived class where necessary but have a protected internal > access > > modifier. > > > > Any suggestions or am I barking up the wrong tree here? > > > > Thanks, > > Mike > > > > =================================== > > This list is hosted by DevelopMentor(r) http://www.develop.com > > > > View archives and manage your subscription(s) at > > http://discuss.develop.com > > > > > > -- > If knowledge can create problems, it is not through ignorance that we can > solve them. > > Isaac Asimov > > =================================== > This list is hosted by DevelopMentor(r) http://www.develop.com > > View archives and manage your subscription(s) at > http://discuss.develop.com > =================================== This list is hosted by DevelopMentor(r) http://www.develop.com View archives and manage your subscription(s) at http://discuss.develop.com
-- If knowledge can create problems, it is not through ignorance that we can solve them. Isaac Asimov =================================== This list is hosted by DevelopMentorĀ® http://www.develop.com View archives and manage your subscription(s) at http://discuss.develop.com