标签:不包含 com copy 不同 多个 内部使用 span href logs
在java中,接口中可以包含字段,但是这些字段隐式地是static和final的。而C#不允许接口中有字段,编译器在编译时就会提示错误(如下代码所示)。
interface IInterface
{ int a ;//编译器错误提示:接口不能包含字段 }
在Java中,方法声明可以带有public修饰符(即使这并非必要),但在C#中,显式地为接口中的方法指定public修饰符是非法的。例如,下面的代码将产生一个编译错误。
interface IInterface { public int add();//错误提示:修饰符“public”对该项无效 }
普通实现接口
interface IInterface { int add(int a,int b) ; } class Program:IInterface { static void Main(string[] args) { Program ii = new Program(); //使用实体类来访问自己的接口函数 Console.WriteLine(ii.add(1, 2));//正确运行,没有提示错误 } public int add(int a, int b) { return a + b; } }
显示地实现接口
interface IInterface { int add(int a,int b) ;//编译器错误提示:接口不能包含字段 } class Program:IInterface { static void Main(string[] args) { Program newProgram = new Program(); newProgram.add(1, 2);//编译器提示错误:“ConsoleApplication3.Program”不包含“add”的定义, //并且找不到可接受类型为“ConsoleApplication3.Program”的第一个参数的扩展方法“add”(是否缺少 using 指令或程序集引用?) } int IInterface.add(int a, int b)//显示实现接口,注意这个方法多了IIterface限定符 { return a + b; } }
另外,我们注意到显式实现接口后int IInterface.add(int a, int b)中少了public修饰符,但是我们一加上编译器又会提示错误:“修饰符“public”对该项无效”。另外因为是Program类访问自身的方法,所以访问性也不是构成add()方法无法访问的原因。
如果我们将main()函数中的代码修改一下,将new Program()的变量赋给IIterface的引用,再看看结果如何
static void Main(string[] args) { IInterface ii = new Program(); Console.WriteLine(ii.add(1, 2));//正确运行,没有提示错误 }
从以上结果,我们可以看出如果是显示实现接口,那么对接口中方法的访问必须要通过接口类型的引用,用显示实现了接口的类是没有办法使用的。
· 由于显式接口成员实现不能通过类或结构实例来访问,因此它们就不属于类或结构的自身的公共接口。当需在一个公用的类或结构中实现一些仅供内部使用(不允许外界访问)的接口时,这就特别有用。
· 显式接口成员实现可以消除因同时含有多个相同签名的接口成员所引起的多义性。如果没有显式接口成员实现,一个类或结构就不可能为具有相同签名和返回类型的接口成员分别提供相应的实现,也不可能为具有相同签名和不同返回类型的所有接口成员中的任何一个提供实现。
标签:不包含 com copy 不同 多个 内部使用 span href logs
原文地址:http://www.cnblogs.com/w-wfy/p/7219208.html