从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(){....;}
类的成员声明中,可以声明与继承而来的成员同名的成员。这是称派生类的成员覆盖了基类的成员。这是会有个警告,使用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(){....;}
相关文章推荐
- 对面向对象,VC,C#的理解
- 浅谈对c# 面向对象的理解
- (教学思路 c#之面向对象二) 初步理解面向对象的基本概念
- 在c#中理解面向对象
- 对于C#中的一些点滴你真的理解了吗?
- dot net 中的C#的重写(override)和重载(overload)的理解
- 深入理解C#第二版笔记
- (C#基础)反射理解
- 关于C#中抽象类与接口的看法与理解
- 正确理解 C# 中的 ref 关键字 (续)
- 对面向对象的理解
- 黑马程序员——C#对面向对象编程的理解
- C#面向对象
- Python3 与 C# 面向对象之~封装
- C#对继承的理解
- 黑马程序员——C#面向对象之索引器
- 深入理解C#中的泛型
- 关于C#中委托的通俗理解
- 第2章 理解面向对象
- JavaSE笔记04:面向对象的理解