I have an explicit conversion setup between two reference types.
class Car
{
public void Foo(Car car)
{
}
public static explicit operator Bike(Car car)
{
return new Bike();
}
}
class Bike
{
}
If I invoke Foo and pass a type of Bike, then I must perform an explicit conversion.
Car myCar = new Car();
Bike bike = (Bike)myCar;
myCar.Foo(bike);//Error: Cannot convert from Bike to Car.
However, if I add an extension method, then explicit conversio is no longer required.
public static void Foo(this Car car, Bike bike)
{
car.Foo(bike);//Success...
}
Why is the extension method able to invoke Foo with a type of Bike implicitly?
Now that you’ve modified the code to show;
All you’ve done is create an ironic StackOverflowException. This method is now just calling itself recursively, not the implementation of
FooinCar.TIP: Get yourself a copy of ReSharper – it’ll put a nice circle-arrow icon on this line of code to show you what’s going on without actually needing to compile or run it. 🙂