在类的继承中,c#允许在基类与派生类中声明具有同名的方法,而且同名的方法可以有不同的代码,也就是说在基类与派生类的相同功能中可以有不同的实现方法,从而解决同一问题提供多种途径。
多态性就是指在程序运行时,执行的虽然是一个调用方法的语句,却可以根据派生类对象的类型不同完成方法不同的具体实现。
在C#中可以通过多种途径实现多态性。
- 虚方法:经父类的方法标记为虚方法,使用该关键字vitrual,此方法在子类中可以重写(使用关键字override)
- 抽象类与抽象方法:如果我们不需要使用父类创建对象,他的存在只是提供子类继承。可以将父类写成抽象(关键字abstract)类,将父类方法写成抽象方法,子类中的方法扔使用重写(override)
- 接口的实现:
我们选择使用虚方法实现多态还是抽象类方法实现多态,取决于我们是否需要使用基类实例化的对象
抽象类:不需要使用基类实例化对象
虚方法:需要使用基类实例化的对象
比如说现在有一个clerk类作为基类,jl类继承clerk,这个时候我们就需要使用虚方法来实现多态了,因为我们要使用clerk创建的对象,这些对象就是普通员工对象。
在比如说,现在一个drink类作为基类,milk,tea类继承drink,我们需要使用的是milk和tea创建的对象,根本不需要使用drink创建对象,所以在这里drink完全可以写成抽象类
类的多态
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace 类的多态之抽象类
{
class jl:clerk
{
public override void write()
{
Console.WriteLine("我是经理,我有工作计划");
}
}
}
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace 类的多态之抽象类
{
class clerk
{
public virtual void write() //两个方法的名字要一样,因为我们要重载和重写
{
Console.WriteLine("我是员工,我有工作计划");
}
}
}
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace 类的多态之抽象类
{
class Program
{
static void Main(string[] args)
{
clerk duw = new clerk();
jl linz = new jl();
clerk[] cll = { duw,linz};
foreach (clerk all in cll)
{
all.write();
}
Console.ReadKey();
}
}
}
类的多态-抽象类
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace 类的多态之抽象类
{
abstract class drink
{
//利用抽象来实现类的抽象化,方法抽象画,并且方法中不能有方法体。
public abstract void write();
}
}
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace 类的多态之抽象类
{
class milk:drink
{
public override void write()
{
Console.WriteLine( "我是牛奶,我可以解渴");
}
}
}
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace 类的多态之抽象类
{
class tea:drink
{
public override void write()
{
Console.WriteLine("我是茶,我可以解渴");
}
}
}
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace 类的多态之抽象类
{
class Program
{
static void Main(string[] args)
{
//drink mmilk = new drink();
////抽象类是不允许创建实例的。
//milk mymilk = new milk();
//tea mytea = new tea();
//这么写也是对的因为我们是继承在drink类中的
drink mymilk = new milk();
drink mytea = new tea();
drink[] mydrink={mymilk,mytea};
foreach (drink ismydrink in mydrink)
{
ismydrink.write();
}
Console.ReadKey();
}
}
}