C++ 实践总结


  1. 对于一个应用程序而言,静态链接库可能被加载多次,而动态链接库只会被加载一次。

  2. Gameloft面试之错误一

Event:

面试官说如下程序是可以链接通过的.

class Base

{

Public:

    Base(void)

    {

      this-> initialize();

}

     virtual void initialize(void) = 0; 

};

 

class Derived : public Base

{

Public:

      virtualvoid initialize(void)

      {

      }

};

 

Base* obj = new Derived;

 

In fact:

  链接根本不能通过,原因:虚函数表是在构造函数调用完成之后才完成初始化的。

 

Summary:

虚拟函数表在对象创建完成后才被初始化,而在构造基类构造函数去掉用虚函数时是无法调用到派生类实现接口的:如下例子链接定会失败(无论gcc还是vs编译器)(总结牢记自己曾今的研究):

 

  1. Gameloft面试之错二

Event:

面试官说如下写法是可通过编译的:

class A

{

     const char* func(const char*const str) const

     {

        char* temp = str;

     }

};

In fact:

  编译时不能通过的: “const char*”类型的值不能用于初始化”char*”类型实体

Summary:

   应坚定地相信自己自己通过科学做出的判断

 

  1. Gameloft面试之错三

Event:

    面试官说如下写法大多数编译器不支持

void(ClassName::  *px)(void);

 

  In fact:

    实践证明,VSGCC编译器均支持该写法

 

  Summary

    该写法并未违背C++标准,应当被支持,至于除VS,GCC之外的编译器未曾了解.

 

  1. 数组指针的初始化及销毁(new/delete)操作:(gameloft面试后思考)

    int (*parr)[10] = (int(*)[10])( new int[10] );

    delete [] parr;

     

  2. 在多继承的时候,dynamic_cast返回nullptr的情况:

    现有2个基类: base1base2

    二级基类:    base3同时继承与base1, base2

    对于对于子类derived, 如果子类是非public继承与base3

    但用基类base2指针保存derived对象时,dynamic_cast转换基类base2指针

    base1指针,会失败返回nullptr

     

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值