Java和C#中的接口对比(有你不知道的东西)

简介:

1.与Java不同,C#中的接口不能包含字段(Field)。

在java中,接口中可以包含字段,但是这些字段隐式地是staticfinal的。而C#不允许接口中有字段,编译器在编译时就会提示错误(如下代码所示)。
interface IInterface            
    {
        int a ;//编译器错误提示:接口不能包含字段
    }

2、在C#和Java中,接口内的所有方法默认都是公用方法。

在Java中,方法声明可以带有public修饰符(即使这并非必要),但在C#中,显式地为接口中的方法指定public修饰符是非法的。例如,下面的代码将产生一个编译错误。 
interface IInterface
    {
        public int add();//错误提示:修饰符“public”对该项无效
    }

3、C#中特有的实现接口和显式实现接口.

普通实现接口
复制代码
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));//正确运行,没有提示错误
        }

从以上结果,我们可以看出如果是显示实现接口,那么对接口中方法的访问必须要通过接口类型的引用,用显示实现了接口的类是没有办法使用的。

显式接口成员实现的两个主要用途

· 由于显式接口成员实现不能通过类或结构实例来访问,因此它们就不属于类或结构的自身的公共接口。当需在一个公用的类或结构中实现一些仅供内部使用(不允许外界访问)的接口时,这就特别有用。

· 显式接口成员实现可以消除因同时含有多个相同签名的接口成员所引起的多义性。如果没有显式接口成员实现,一个类或结构就不可能为具有相同签名和返回类型的接口成员分别提供相应的实现,也不可能为具有相同签名和不同返回类型的所有接口成员中的任何一个提供实现。

本文转自陈哈哈博客园博客,原文链接http://www.cnblogs.com/kissazi2/p/3291730.html如需转载请自行联系原作者

kissazi2
相关文章
|
1月前
|
IDE C# 开发工具
C#系列之接口介绍
C#系列之接口介绍
|
3月前
|
达摩院 Linux API
阿里达摩院MindOpt求解器V1.1新增C#接口
阿里达摩院MindOpt求解器发布最新版本V1.1,增加了C#相关API和文档。优化求解器产品是求解优化问题的专业计算软件,可广泛各个行业。阿里达摩院从2019年投入自研MindOpt优化求解器,截止目前经历27个版本的迭代,取得了多项国内和国际第一的成绩。就在上个月,2023年12月,在工信部产业发展促进中心等单位主办的首届能源电子产业创新大赛上,MindOpt获得电力用国产求解器第一名。本文将为C#开发者讲述如何下载安装MindOpt和C#案例源代码。
139 3
阿里达摩院MindOpt求解器V1.1新增C#接口
|
3月前
|
编译器 C# 开发者
C# 11.0中的新特性:覆盖默认接口方法
C# 11.0进一步增强了接口的灵活性,引入了覆盖默认接口方法的能力。这一新特性允许类在实现接口时,不仅可以提供接口中未实现的方法的具体实现,还可以覆盖接口中定义的默认方法实现。本文将详细介绍C# 11.0中接口默认方法覆盖的工作原理、使用场景及其对现有代码的影响,帮助开发者更好地理解和应用这一新功能。
|
3月前
|
安全 C# 开发者
C#中的默认接口方法:接口演化的新篇章
【1月更文挑战第11天】本文探讨了C# 8.0中引入的默认接口方法,这一特性允许在接口中定义具有默认实现的方法。文章介绍了默认接口方法的语法、使用场景,以及它们如何影响接口的设计和实现,同时讨论了默认接口方法带来的好处和潜在的陷阱。
|
7月前
|
设计模式 自然语言处理 C#
C#OOP之八 继承 接口和抽象类
C#OOP之八 继承 接口和抽象类
27 0
|
3月前
|
C# 开发者 索引
C# 11.0中的所需成员:强化接口与抽象类的约束
【1月更文挑战第24天】C# 11.0引入了所需成员(Required members)的概念,这一新特性允许在接口和抽象类中定义必须被实现的成员,包括方法、属性、索引器和事件。通过所需成员,C# 强化了对接口实现和抽象类继承的约束,提高了代码的一致性和可维护性。本文将详细探讨C# 11.0中所需成员的工作原理、使用场景及其对现有编程模式的影响。
|
4月前
|
Java C# C++
【从Java转C#】第八章:委托、lambda、事件
【从Java转C#】第八章:委托、lambda、事件
|
4月前
|
存储 Java C#
【从Java转C#】第七章:运算符和类型强制转换
【从Java转C#】第七章:运算符和类型强制转换
|
4月前
|
Java C# 索引
【从Java转C#】第六章:数组
【从Java转C#】第六章:数组
|
4月前
|
存储 Java 编译器
【从Java转C#】第五章:泛型
【从Java转C#】第五章:泛型