c++面经积累<1>

  1. 引用和指针
    • 指针是一个实体,需要分配内存空间,而引用只是一个别名,不需要分配内存空间
    • 指针可以有多级,而引用只能有一级。
    • 指针和引用的自增运算不一样,指针是指向下一个空间,而引用是引用的变量值增加
    • sizeof引用得到引用所指对象的大小,而sizeof指针得到指针的大小。
  2. static的用法和介绍
    • 隐藏:未加static修饰的全局变量和函数具有全局可见性。
    • 保持变量内容的持久。
    • 默认初始化为0
    • 在类中使用static
      • 函数体内的static变量作用范围为该函数体。
      • 类中的static变量修饰的成员函数属于整个类,这个函数不包括this指针,因为只能访问类的static成员变量
      • static成员函数不能被virtual修饰,static成员不属于任何对象或实例。
  3. 构造函数和析构函数类相关
    1. 构造函数为什么不能为虚函数?析构函数为什么要为虚函数?
      • 虚函数相当于一个指向虚函数表的指针,这个指针存在于对象的内存空间中,如果构造函数是虚函数,那么在对象初始化之前就应该存在。但是此时对象还未初始化,因为构造函数不能是虚函数
      • 当派生类对象申请了内存空间,并在析构函数中对这些内存进行释放,如果析构函数采用非析构,那么删除基类指针指向的派生类的对象的时候,就不会发生动态绑定,因为只会调用基类的析构函数,而不会调用派生类的析构函数。
    2. 构造函数和析构函数中可以调用虚函数吗?
      • 不提倡在构造函数和析构函数中调用虚函数
      • 构造函数和析构函数中调用虚函数都不使用动态绑定。如果在其中调用虚函数,那么运行的是为构造函数和析构函数自身定义的版本。
      • 父类对象在子类对象之前进行构造,此时子类部分的数据成员还未进行初始化。因此调用子类的虚函数是不安全的。
      • 析构函数用来销毁一个对象,在销毁一个对象的时候,先调用子类的析构函数,然后调用基类的析构函数,故在调用基类的析构函数的时候,派生类的数据成员已经被销毁,在调用子类的虚函数没有任何意义。
    3. 构造函数析构函数是否可以抛出异常
      1. c++只会析构已经完成的对象,在构造函数中抛出异常,控制权转出构造函数之外,因而在对象b的构造函数中发生异常,对象b的析构函数不会被调用,因此发生泄漏
      2. 如果从析构函数抛出异常,而且没有在当地进行捕捉,那么析构函数执行不完全。

猜你喜欢

转载自www.cnblogs.com/tingweichen/p/10780977.html
今日推荐