您的位置:首页 > 编程语言 > C#

从C#谈对面向对象的理解点滴(一)

2007-09-04 17:32 211 查看
1.覆盖:
类的成员声明中,可以声明与继承而来的成员同名的成员。这是称派生类的成员覆盖了基类的成员。这是会有个警告,使用new 关键字可以关闭这个警告。
2.Base保留字:
Base关键字主要是为派生类调用基类成员提供一个简写的方法。

3.C#中的多态:
多态的定义:同一操作作用于不同的类的实例,不同的类将进行不同的解释,最后产生不同的执行结果。
编译时的多态性:
编译时的多态性是通过重载来实现的。对于非虚的成员来说,系统在编译时,根据传递的参数、返回的类型等信息决定实现何种操作。
运行时的多态性:
运行时的多态性是指直到系统运行时,才根据实际情况决定实现何种操作。C#中,运行时的多态性通过虚成员实现。
编译时的多态性为我们提供了运行速度快的特点,而运行时的多态性则带来了高度灵活和抽象的特点。

4.虚方法:
使用virtual修饰符的方法,成为虚方法,反之为非虚。使用virtual不能和static,abstract,override修饰符同时使用。
如果基类调用某个被派生类重载(Override)过的方法,该方法的执行代码是派生类中被重载过得方法。如:
Class A
{
public void F()
{
Console.WriteLine("A.F");
}

public virtual void G()
{
Console.WriteLine("A.G");
}
}

class B : A
{
new public void F()
{
Console.WriteLine("B.F");
}

public override void G()
{
Console.WriteLine("B.G");
}
}

class show
{
public void main(args[] string)
{
B b = new B();
A a = b;
a.F();
b.F();
a.G();
b.G();
}
}
上面执行的结果是:
A.F
B.F
B.G
B.G
也就是说被override过的方法,基类里的方法也会被更改。但new(覆盖)就不同了,new只会覆盖派生类中从基类继承过来的方法,不会改变基类的方法。这有点像地址传递和值传递。

5.抽象类abstruct class:
抽象类只能作为其他类的基类,不能直接被实例化,而且对抽象类不能使用new操作符。
抽象类允许包含抽象成员,虽然这不是必须的。也就是说有抽象成员的类一定是抽象类,但没有抽象成员的类也可能是抽象类。
抽象类不能同时又是密封的。
抽象方法可以重载(Override)一个虚方法(Virtual),但抽象方法没有其执行体,只要有方法的原型。

6.密封类(sealed class):
密封类不能被任何类继承。
密封方法必须对基类的虚方法进行重载,提供具体的实现方法,所以在方法的声明中,sealed修饰符总是和override修饰符同时使用。sealed override void F(){....;}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: