虚指针(vptr) 和 虚表(vtbl)

虚指针

在类中,一个对象的大小取决于类内的数据成员的大小之和。但是如果类存在着虚函数,不管虚函数的多少。那么类的大小是数据成员之和 + 一个虚指针(指向虚表)。每个存在着虚函数的类,都会有一个对应的虚表,虚表里面都是函数指针,他们分别指向自己类对应的虚函数。如果继承了父类,且实现了相应的虚函数,那么子类的虚表中,不会存在实现了子类虚函数对应的父类虚函数。而没有实现的父类虚函数则会存在子类的虚表中。

绑定

前提:执行到某一条指令时。需要调用某个函数
静态绑定:编译器直接编译为调用该函数的地址。
动待绑定:编译器将调用方式转为用指针指向某个函数。这样指针指向的函数地址不同,则执行的函数就不同,从而达到在运行时从才会确定该指针指向的函数。

虚函数的用法(多态的表现)

我们在创建对象时,对象就会有一个对应的内存。内存中已经有一个固定的虚指针,指向了对象的类的虚表。当我们将该对象的指针转成父类的指针,其虚指针执行的虚表不会被改变。调用该函数时同样会指向创建时的类的虚表指向的函数。从而达到使用父类的指针类型,调用到各个子类相对应的函数。

const

const修饰成员函数时,表示的该函数在运行过程中不会改边数据成员的值。并不关心返回值会不会被改变。
const修饰函数,只会用在成员函数中。有const 和 无const 在编译器眼里是两个函数,即两个函数是重载。当同时存在有 const 函数 和 无const 函数时,const 对象调用 const 函数, 无const对象调用 无const 函数。
本质:const 修饰的成员函数时,编译器会将this指针指向的对象 编译为 const 。在所有函数的重载中,有无const 修饰指针指向的对象可以实现函数重载,有无const 修饰的对象不可以实现函数重载。

new 和 delete

new 和 delete 是表达式,是不可以重载的。

new 是先调用 operator new(size_t)或是 operator new[](size_t) ,接着将指针类型转换,最后调用相应的构造函数(如果是数组则调用n个构造函数)。
delete 是先 调用相应的析构函数(如果是数组则调用n次析构函数),再调用 operator delete(void*,size_t) 或是 operator delete[](void* ,size_t)释放内存。
当我们在类中重载了 operator new , operator new[], operator delete, operator delete[],时,创建对象则调用类内的重载函数。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值