静态联编和动态联编

本文介绍了C++中的联编概念,包括静态联编和动态联编。静态联编(早期联编)在编译时确定函数调用,常发生在函数重载的情况下。动态联编(晚期联编)涉及虚函数,其调用在运行时决定。此外,还讨论了指针和引用类型的兼容性,包括向上和向下强制转换,强调了基类引用或指针可以隐式转换为派生类,而派生类到基类的转换需要显式操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、什么是联编
将源代码中的函数调用解释为执行指定的函数代码块被称为函数名联编(binding)
2、什么是静态联编
因为每个函数名对应于一个不同的函数。在c++中由于函数重载。使得编译器必须查看函数参数以及函数名才能确定使用哪个函数,因此在编译过程中进行联编被称为静态联编(static binding)又称为早期联编(early binding)
3、什么是动态联编
当有虚函数存在时,使用哪一个函数是不能再编译时确定的,所以编译器必须生成能够在程序运行时选择正确的虚方法的代码,这称为动态联编(dynamic binding)又称为晚期联编(late binding)
4、指针和引用类型的兼容性–向上强制转换和向下强制转换
动态联编与通过指针和引用的调用方法相关。从某种程度上说这是由继承控制的。公有继承的is-a关系的一种方法使如何处理指向对象的指针和引用。通常c++不允许将一种类型的地址赋给另一种类型的指针,也不允许一种类型的引用指向另一种类型。

指向基类的引用或指针可以引用派生类对象,并且不必进行显式类型转换。

BrassPlus dilly("Annie Dill",493222,2000);
Brass *pb=&dilly;
Brass &rb=dilly;

(1)向上强制转换
将派生类引用或指针转换为基类引用或指针称为向上强制转换,隐式的

BrassPlus dilly("Annie Dill",493222,2000);
Brass*pb=&dilly;
Brass*rb=dilly;

(2)向下强制类型转换
将基类的指针或引用转换为派生类指针或引用,必须使用显式类型转换。因为派生类可以新增数据成员,因此使用这些数据成员的类成员函数不能应用于基类。

例子说明向上转换
使用基类引用或指针作为参数的函数调用

Brass 基类
BrassPlus派生类
ViewAcct()方法使虚的
void fr(Brass & rb);//use rb.ViewAcct()
void fp(Brass *pb);//use pb->ViewAcct()
void fv(Brass b);//use b.ViewAcct()
int main()
{
   Brass b("Billy Bee",123432,10000.0);
   BrassPlus bp("Betty Beep",232313,12345.0);
   fr(b);//use Brass::ViewAcct()
   fr(bp);//use BrassPlus::ViewAcct()
   fp(b);//use Brass::ViewAcct()
   fp(bp);//use BrassPlus::ViewAcct()
   fv(b);//use Brass::ViewAcct()
   fv(bp);//use Brass::ViewAcct()
}

使用虚方法时,根据指针或引用指向的对象类型调用。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值