Есть способ ... если вы определили 2 новых типа, чтобы компилятор мог различать две разные подписи ...
public struct EmployeeId
{
public int val;
public EmployeeId(int employeeId) { val = employeeId; }
}
public struct HRId
{
public int val;
public HRId(int hrId) { val = hrId; }
}
public class Employee
{
public int EmployeeId;
public int HrId;
// other stuff
}
public class Employees: Collection<Employee>
{
public Employee this[EmployeeId employeeId]
{
get
{
foreach (Employee emp in this)
if (emp.EmployeeId == employeeId.val)
return emp;
return null;
}
}
public Employee this[HRId hrId]
{
get
{
foreach (Employee emp in this)
if (emp.HRId == hrId.val)
return emp;
return null;
}
}
// (or using new C#6+ "expression-body" syntax)
public Employee this[EmployeeId empId] =>
this.FirstorDefault(e=>e.EmployeeId == empId .val;
public Employee this[HRId hrId] =>
this.FirstorDefault(e=>e.EmployeeId == hrId.val;
}
Тогда, чтобы позвонить, вы должны написать:
Employee Bob = MyEmployeeCollection[new EmployeeID(34)];
А если вы написали неявный оператор преобразования:
public static implicit operator EmployeeID(int x)
{ return new EmployeeID(x); }
тогда вам даже не нужно будет это делать, вы можете просто написать:
Employee Bob = MyEmployeeCollection[34];
То же самое применимо, даже если два индексатора возвращают разные типы ...