本篇可看做是下一节虚机制的前置内容,如果您仅希望了解有关动态联编和静态联编的问题,请无视这个提示,这不影响对联编知识的介绍。
如果您也像博主一样正在学习C++,在完成本篇博客阅读后建议继续阅读有关虚机制的内容
传送门
联编
先不论动态还是静态,首先需要明确的是关于“联编”的含义,书中有这样的说明:
将源代码中的函数调用解释为执行特定函数代码块被称为函数名联编(binding)
这里有必要说明一下,有些地方对于binding的翻译是绑定也有些地方把它叫编联,但实际上他们都指的这同一个单词,所以使用哪种翻译都可以,只是他们容易对初次接触概念的同学造成困扰。
通俗些说,就是指明调用函数的语句调用的究竟是哪一个函数,执行哪一个函数下的代码块。也可以说是明确调用关系,指明那条语句调用了那个函数。我们来看一个栗子:
#include<iostream>
using namespace std;
class A{
public:
void f(){
cout << "func f in class A" << endl;}
};
void f(){
cout << "global func f" << endl;}
int main()
{
A a;
f();
a.f();
}
这个例子再简单不过了,要辨别主函数中两条语句调用的是哪一个函数简直就是小学二年级的问题 。
明确f()
调用的是定义在全局的f函数
,a.f()
调用的是A类中的f成员函数
的过程就是联编。只不过这项工作实际上需要编译器来完成的,并且联编的结果不是一两句话而是一个个函数的地址。
静态联编
现在,知道了编联的含义,就可以来讨论有关静态和动态联编的意义了。
首当其冲 首先介绍的是静态联编。
静态联编指的是联编的工作在编译期间完成,书上有这样的介绍:
C/C++编译器可以在编译过程完成这种联编。在编译过程中进行联编被称为静态联编(static binding),又称为早期联编(early binding)
没错,这里