C#基类和派生类
class B : A{}
A是基类,B是派生类.
一个类最多只允许从一个类中派生.
class C : B{}
B还可以充当C的派生类
继承总是隐式为public的,System.Object是所有类的根
编译器会把你的类悄悄的编译成 class A : System.Object{}
class B : A
{
public B(string sqlstr) : base(sqlstr)
{}
}
class A{}
class B : A {}
class C: A {}
B b = new B();
C c = b; //这样写是错误地,因为类型不同
A a = b; //这样写是正确的,但是一定要注意:
这样做有一个明显的限制 a 对象只能访问基类中的成员不能访问派生类中的成员
这就是为什么C#完全面向对象的原因,因为C#中所有的东西都继承自System.Object,任何东西都能赋给一个object变量
如果一个基类有n个方法和n个派生类,这n个派生类里又分别有n个方法.你想过会出现什么问题吗?对!就是会遇到完全一样签名的方法(方法名\参数的数量\类型完全一样)
但是你应该认真的对待这个警告,如果派生类的一个对象将调用基类的一个方法,然而这个方法又在这个派生类里有相同签名的方法!那编译器该怎么办?
我可以负责任的告诉你(呵呵):
对象调用的是派生类里的方法,
这种现象在微软官方叫方法的隐藏,
先看个例子:
程序很简单(原谅我用了中文拼音,我知道你看了很多国外的程序,肯定腻了)
当调用第三个WriteLine时,程序输出了"这是个女人",现在不用我解释你也该明白了.
这种同一个语句调用不同方法的现象称为多态性(面向对象的一大特性啊!)
使用virtul和override一定要注意:
(1)两个方法必签名相同!
(2)两个方法均不能是private方法,且必须有相同的可访问性!
(3)不要试图override没有virtual的方法!
(4)不要试图不用override就覆盖基类的virtual方法(那就成了方法的隐藏了)!
在给你个小窍门:
一个override方法将隐式的成为virtual方法,他本身可在未来的一个派生类里被覆盖(点到为止,不要让我写例子给你)
这篇小文到次也该结束了,但我还想再提两句
1.派生类可以访问一个基类的protected成员
2.建议保持字段为private. ( 因为面向对象强调封装,而public破坏了封装性,private也会在某些时候破坏封装性,你应该知道是哪些时候.呵呵)