我们为什么需要索引器(indexer)这种玩意儿?
当我们要定义一个自定义的集合类型时,比如EmployeeCollection , ManagerCollection .因为功能的需要,我们在这样的类中,我们使用了泛型的集合类做存储,还需要在类中封装一些其它的必要的相关方法,比如计算工资的方法呀,查看员工有多少个WORKING DAYS的方法呀,之类的。这样子,我们的泛型存储集合类的索引器功能就被封装在类里头了,而我们出于封装的考量,不可能直接就用EmployeeCollection.EmployeeList[] ,这样子来直接访问我们的内部存储,于是我们就要把存储集合类对象设置为私有,然后设置访问它们的方法 : AddEmployee(), RemoveEmployee(),GetEmployee()这样的方法。但是,这种做法真的称不上简洁,我们希望自定义的类也像集合类本身一样支持这样的 [] 使用方式,并且是安全的可以控制的方式来实现:
EmployeeCollection[0]=new Employee("name");
. . .
Console.WriteLine(EmployeeCollection[i].Name);
鉴于以上需求,就像曾经用属性property封装了某些私有成员变量一样,这儿,我们也需要一种机制来把成员集合类来封装起来,这个机制,就叫索引器(indexer)。如下:
public ElementsType this[int index]
{
get{ return EmployeeList[index];};
ser{ EmployeeList[index]=value;};
}
这儿我们使用了this[] 关键字组,这是个规定的语法,必须如此,然后里面有get ,set ,是不是跟property很像呀,呵呵。。。。。它就是指明了当使用前面的索引结构时,类集合如何返回,或者设置指定的元素。跟我们在类中自定义存取,访问方法的功能是一样的。
当我们的自定义集合类中是使用List<T>这样的使用int 索引的集合类型时,我们通过索引器用int 索引整个自定义集合类,当我们的自定义集合类中使用的是Dictionary<TKey,TValue>这样的用string索引的集合类型时,我们的索引器也可以定义为用string 索引的访问方式。具体用法查书。索引器有时候还可以被重载使用,甚至还可以定义多维的索引器。。。。。。
运算符重载,跟C++差球不多。。。但,C++中不能重载 +=,-=,在C#中可以了。并且,如果重载了+,-这样的二无运算符,这些+=,-=功能自动就有了。LOOK,这就是语言的进化。。。。。
另外,C#中,类型转化这种事情也可以自定义,比如你要将一个 Employee类的对象转化为继承自它的Manager类的对象,这个过程中发生的事情,可以自己定义。
一直在说,.NET平台有两种主要的类型:值类型,引用类型。但事实上还有一种类型:指针类型!使用指针类型,可以绕开CLR的内存管理机制,自己处理。这就是.NET中所谓的 unsafe 代码。