Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Type Parameter Unification

Why is this disallowed in C#? alt text http://img706.imageshack.us/img706/7360/restriction.png

Actually I'd like to be able to write

alias Y<A, B> : X<A, B>, X<B, A>

The unification is actually desired here; if the A = B then just one method should be defined.

like image 654
Bent Rasmussen Avatar asked Feb 28 '23 10:02

Bent Rasmussen


1 Answers

The first reason that comes to mind is the following.

class Example : Y<int,int> {
 ...
}

In this case the type Y implements the same interface twice but can have differing implementations of the same method. This creates an unresolvable ambiguity in the compiler for the method Tx in both implementation and calling.

For example take the following problem.

class OtherExample<A,B> : Y<A,B> {
  B Tx(A x) { 
    Console.WriteLine("Top method in the file");
    return default(B); 
  }
  A Tx(B x) { 
    Console.WriteLine("Bottom method in the file");
    return default(A);
  }
}

If you ignore the unification error this is a legal implementation of Y<A,B>. Now imagine the user did the following

var v1 = new OtherExample<int,int>();
v1.Tx(42);

What exactly would happen in this scenario? How would the compiler, or the CLR for that matter, be able to resolve the ambiguity? You'd have identically named methods with identical signatures.

like image 55
JaredPar Avatar answered Mar 11 '23 05:03

JaredPar