概念:
早绑定指的是在编译阶段进行绑定
迟绑定指的是执行阶段绑定
样例:
Class Base
{
void fun(){}
}
Class Bind :Class Base
{
Void fun(){}
}
main()
{
Base base;
base->fun();
Bind *tmp;
tmp = &base;
tmp->fun();
}
上面的样例说明大家一个是不是有语法问题,事实上我是有益的,fun函数被覆盖了
先来说说base->fun();是怎么一个过程吧。
程序执行时创建了base对象。base->fun();算什么呢?
假设你理解成对象对调用了对象中的函数的话,那就变成执行时去找到函数了。那说好的早绑定呢?
c++编译时。base->fun()事实上等价于fun(base),这样一看不就是函数地址吗!确实是函数地址,
这也间接说明了c++中的成员函数就是一个唯一全局地址。而对象就是一个被隐藏了的入參。
早绑定指的是在编译阶段就决定了怎样调用。编译确定了调用地址。当然就确定了调用方式,所以说是早绑定。
tmp->fun为什么会调用Bind的fun函数,是由于c++通过函数名+变量类型+变量个数来唯一确定全局唯一函数。
这也是为什么c++函数的调用设计方式和c不一样的原因吧。
事实上当你正在理解了早绑定技术。我觉得自己也能够搞定迟绑定技术。
迟绑定就是用来解决多态特性的(多态特性这里不做说明)
迟绑定也就是说就算赋值了,也能正确的调用正确的函数。
c++的解决方式是:
当调用函数时检查到了一个特殊标记(virtual),就不直接调用地址了,就中base对象中取出一个vptr。
vptr指向了虚表。这样就能够正确的找到函数进行调用了。也就是绕一下并且,
当然说起来简单,实现这种功能还是有难度的。
替代的解决方式:
直接把虚函数保存到对象中,检查到特殊标记(vitrual)时,直接得到函数地址进行调用,
当让我想的方案是不成熟了。仅仅是为了说明迟绑定就是我们寻常也常常会用到的技术。并
不是神奇的。特殊的,复杂的。