Assist知识点:虚函数只能借助于指针或者引用来达到多态的效果。
#include <iostream>
using namespace std;
class A
{
public:
virtual void foo()
{
cout << "A::foo() is called" << endl;
}
};
class B :public A
{
public:
void foo()
{
cout << "B::foo() is called" << endl;
}
};
int main(void)
{
A *a = new B();
a->foo();
return 0;
}
这里输出结果是B::foo() is called
class A{
void fun() {
System.out.println("A is");
}
}
class B extends A{
void fun() {
System.out.println("B is");
}
}
public class Solution {
public static void main(String[] args) {
A a=new B();
a.fun();
}
}
这里输出的结果是B is
那么问题就来了?为什么c++中a虽然是指向A的指针,但是被调用的函数(foo)却是B的,而JAVA中同样建立了A类型的对象的引用指向B,为何输出也是B的?
这里实际上就是多态的表现。
C++:由于编写代码的时候并不能确定被调用的是基类的函数还是哪个派生类的函数,所以被成为"虚"函数。
Java:对象的引用指向B堆上,所以调用的是B的方法