奇虎360一面

岗位:IOS研发

面试题目:

1. 虚函数的实现原理

2. 如果申明A类的两个对象,那么这个虚函数表在内存中是怎么表示的,放在什么位置?

   点评:多个A的对象共享一个虚表,虚表一般放在进程的常量数据区中。

3. 既然多个对象公用一个虚函数表,那么申明一个新的A类对象的时候指针是怎么找到这个虚函数表的?

4. n个结点(相同)构成一颗二叉树,然后再用这些结点构成一棵树,问构成的这两个种类谁多谁少?

   点评: 二叉树比树多,二叉树和树林存在一一映射关系,二叉树并不是树的子集,因为树是不 分左右孩子节点的。

5. 多重虚继承在内存中如何表示的?比如BC同时虚继承于AD分别继承BC,然后画出D的内存模型,然后如果申明C *p=new D(),那么使用什么机制可以使p访问到A中的内容

   点评:D中是共享一个共同的A对象的,BC中都有一个虚指针指向A的开始地址,便于访问  A中的内容,那么在D中就有A + B 中不属于A的 +C中不属于A+B指向A的虚指针+ C指向A的虚指针。因此可以通过虚指针访问自己的基类。

6. 时间片轮转调度算法中当时间片到了以后怎么进行进程切换的(什么机制)?

   点评:CPU有一个时钟周期,硬件上的,每当CPU时钟周期到了就陷入时钟中断,进入操作系统的进程调度程序,随即进行进程的上下文切换。

   时间片轮转调度会引起CPU的效率降低,在进行上下文切换的时候,非时钟轮转调度算法虽然缺点很多,但是也有优点,比如CPU效率高,实现简单(不用考虑进程的同步互斥?)

7. 抢占式调度算法和非抢占式调服算法的优缺点?主要是说明一下非抢占式的优点

8. 在单核CPU中,线程本质上不是并发执行的,而是一个线程一个线程执行的,那么在单核CPU中可以不加锁机制吗?

   点评:依然需要加锁机制。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值