如何理解C#中对于接口的实现方式,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。
创新互联公司长期为近千家客户提供的网站建设服务,团队从业经验10年,关注不同地域、不同群体,并针对不同对象提供差异化的产品和服务;打造开放共赢平台,与合作伙伴共同营造健康的互联网生态环境。为枝江企业提供专业的成都做网站、网站建设,枝江网站改版等技术服务。拥有十多年丰富建站经验和众多成功案例,为您定制开发。C#中对于接口的实现方式有隐式接口和显式接口两种:
隐式地实现接口成员
创建一个接口,IChinese,包含一个成员 Speak;我们创建一个类Speaker,实现接口Chinese
//隐藏式实现例子public interface IChinese{ string Speak();}public class Speaker : IChinese{ public string Speak() { return "中文"; }}
这个就是隐式实现接口。
隐式实现调用方法如下:
IChinese s = new Speaker();s.Speak();Speaker s = new Speaker();s.Speak();
都可以调用Speak这个方法。
创建一个接口,IEnglish,包含一个成员 Speak;让我们的类Speaker来实现接口IEnglish
//显式实现例子public interface IEnglish{ string Speak();}public class Speaker : IEnglish{ string English.Speak() { return "English"; }}
通过这种显示接口实现。Speak方法就只能通过接口来调用:
IEnglish s = new Speaker();s.Speak();
下面的这种方式将会编译错误:
Speaker s = new Speaker();s.Speak();
隐式实现和显示实现的区别:
一、语法的区别
1、隐式方式Speaker的成员(Speak)实现有而且必须有自己的访问修饰符(public),显示实现方式Speaker的成员(Speak)不能有任何的访问修饰符。2、显示实现方式Speaker使用接口名称和一个句点命名该类成员(Speak)来实现的:English.Speak();也就是
二、调用的区别
隐式接口实现的调用,注意类的声明,可以用接口声明,也可以用实现类 Speaker声明。调用者都可以得到调用实例化对象的行为Speak;
class Program{ static void Main(string[] args) { IChinese s = new Speaker(); s.Speak(); Speaker s = new Speaker(); s.Speak(); }}
显式接口实现调用,注意类的声明,只可以用接口声明,调用者才可以可以得到调用实例化对象的行为Speak;
class Program{ static void Main(string[] args) { IEnglish s = new Speaker(); s.Speak(); //下面写法将引起编译错误错误“PetShop.Speaker”不包含“Speak”的定义; // Speaker s = new Speaker(); // s.Speak(); }}
结论:
隐示实现对象声明为接口和类都可以访问到其行为,显示实现只有声明为接口可以访问。
如果两个接口中有相同的方法名,那么同时实现这两个接口的类,就会出现不确定的情形,在编写方法时,也不知道实现哪个接口的方法了。为解决这一问题,C#提供了显示接口实现技术,就是在方法名前加接口名称,用接口名称来限定成员。用“接口名.方法名()”来区分实现的是哪一个接口。
注意:显示接口实现时,在方法名前不能加任何访问修饰符。这种方式和普通方法不同,普通方法前不加访问修饰符,默认为私有的,而显式接口实现时方法前不加任何修饰符,默认为公有的,如果前面加上修饰符,会出现编译错误。
调用显示接口实现的正确方式是通过接口引用,通过接口引用来确定要调用的版本。
下面我们看一下完整实例:
using System;public interface IPerson{ string Name { get; set; } void Show(string name);}public interface IStudent{ string StudentId { get; set; } void Show(string studentid);}public class Student: IPerson, IStudent{ private string _name; public string Name { get { return _name; } set { _name = value; } } private string _studentid; public string StudentId { get { return _studentid; } set { _studentid = value; } } void IPerson.Show(string name) { Console.WriteLine("姓名为{0}", name); } void IStudent.Show(string studentid) { Console.WriteLine("学号为{0}", studentid); }}class Program{ static void Main() { Student s = new Student(); Console.WriteLine("输入姓名"); s.Name = Console.ReadLine(); Console.WriteLine("输入学号"); s.StudentId = Console.ReadLine(); IPerson per = s; per.Show(s.Name); IStudent stu = s; stu.Show(s.StudentId); }}
看完上述内容,你们掌握如何理解C#中对于接口的实现方式的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注创新互联行业资讯频道,感谢各位的阅读!
分享标题:如何理解C#中对于接口的实现方式-创新互联
转载来于:http://scpingwu.com/article/dcdopi.html