80

If we have a class that inherits from multiple interfaces, and the interfaces have methods with the same name, how can we implement these methods in my class? How can we specify which method of which interface is implemented?

0

9 Answers 9

117

By implementing the interface explicitly, like this:

public interface ITest { void Test(); } public interface ITest2 { void Test(); } public class Dual : ITest, ITest2 { void ITest.Test() { Console.WriteLine("ITest.Test"); } void ITest2.Test() { Console.WriteLine("ITest2.Test"); } } 

When using explicit interface implementations, the functions are not public on the class. Therefore in order to access these functions, you have to first cast the object to the interface type, or assign it to a variable declared of the interface type.

var dual = new Dual(); // Call the ITest.Test() function by first assigning to an explicitly typed variable ITest test = dual; test.Test(); // Call the ITest2.Test() function by using a type cast. ((ITest2)dual).Test(); 
Sign up to request clarification or add additional context in comments.

4 Comments

what if Test() is declared public in both the interfaces and the Dual class?
Methods/properties on an interface are always public - that is the entire point of an interface. But when you use an explicit interface implementation, the function will always be private on the class. That is why you need the technique to cast the class to the specific interface that you need. When you do implement two interfaces that define methods with identical signature, you cannot avoid this.
Do note another subtle "feature" of this is that each method can have a different return type even if they have the same method signature. If you don't use explicit interface declaration on all or all but one of the methods, this isn't normally allowed.
@R.S.K If Test() is declared in the Dual class, it will be used by both interfaces as the implementation. You won't be able to have the other two explicit implementations along with that.
13

You must use explicit interface implementation

Comments

9

You can implement one or both of those interfaces explicitly.

Say that you have these interfaces:

public interface IFoo1 { void DoStuff(); } public interface IFoo2 { void DoStuff(); } 

You can implement both like this:

public class Foo : IFoo1, IFoo2 { void IFoo1.DoStuff() { } void IFoo2.DoStuff() { } } 

Comments

8

You can implement one interface Explicitly and another implecitely.

public interface ITest { void Test(); } public interface ITest2 { void Test(); } public class Dual : ITest, ITest2 { public void Test() { Console.WriteLine("ITest.Test"); } void ITest2.Test() { Console.WriteLine("ITest2.Test"); } } 

ITest.Test will be the default implementation.

Dual dual = new Dual(); dual.Test(); ((ITest2)dual).Test(); 

Output:

Console.WriteLine("ITest.Test"); Console.WriteLine("ITest2.Test"); 

Comments

4

Sometimes you may even need to do:

public class Foo : IFoo1, IFoo2 { public void IFoo1.DoStuff() { } public void IFoo2.DoStuff() { ((IFoo1)this).DoStuff(); } } 

2 Comments

Versus creating a temporary of the correct interface type? No thanks. readonly IFoo1 this1 = this; this1.DoStuff();
Inheritable classes which include code in explicit interface implementations often cause trouble for derived classes. I would suggest as an alternate pattern having a protected method with the code for both interface members, and having both interface members chain to that. Casting this to an interface type for the purpose of using a member thereof is generally a significant code smell. Better to have a protected method which implements the member in question and chain to that.
3
public class ImplementingClass : AClass1, IClass1, IClass2 { public override string Method() { return "AClass1"; } string IClass1.Method() { return "IClass1"; } string IClass2.Method() { return "IClass2"; } } 

So when calling from different class you will have to type cast the object into required Interface or Abstract class.

ImplementingClass implementingClass = new ImplementingClass(); ((AClass1)implementingClass).Method(); 

Comments

2
public interface IDemo1 { void Test(); } public interface IDemo2 { void Test(); } public class clsDerived:IDemo1,IDemo2 { void IDemo1.Test() { Console.WriteLine("IDemo1 Test is fine"); } void IDemo2.Test() { Console.WriteLine("IDemo2 Test is fine"); } } public void get_methodes() { IDemo1 obj1 = new clsDerived(); IDemo2 obj2 = new clsDerived(); obj1.Test();//Methode of 1st Interface obj2.Test();//Methode of 2st Interface } 

Comments

1

Answer is "By using explicit Interface implementation"

Take one example:

using System; interface A { void Hello(); } interface B { void Hello(); } class Test : A, B { void A.Hello() { Console.WriteLine("Hello to all-A"); } void B.Hello() { Console.WriteLine("Hello to all-B"); } } public class interfacetest { public static void Main() { A Obj1 = new Test(); Obj1.Hello(); B Obj2 = new Test(); Obj2.Hello(); } } 

Output:

Hello to all-A Hello to all-B 

Comments

0
 Dual dual = new Dual(); (dual as ITest).Test(); (dual as ITest2).Test(); 

you can use that for your code

Comments

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.