[C++面试高频]C++基础(七)

1.堆为什么比栈效率低

栈申请的速度快

存储寻址速度快

CPU硬件操作速度快,CPU有专门的寄存器操作栈,而堆使用间接寻址,所以栈快。

2.二叉树使用来干什么的

常用来实现二叉查找树(用于搜索和动态排序)和二叉堆(快速获取集合最值)

3.红黑树了解吗?使用来干什么的。

①C++中map和set都是红黑树实现的。

②也用于实现Linux操作系统的CPU调度。

4.说说哈希表,如何避免哈希冲突?

哈希表可以实现常数时间复杂度的查找。

通过键值对实现,键和值一一对应。

用哈希函数获取键值对的哈希值,对应数组下标。

避免哈希冲突:

①开放地址法。有哈希冲突,将数据插到下一个位置,若还有,一直往下走直到能插入。

②二次探测法。有哈希冲突时,下次插入位置为当前位置加n的二次方。

③链地址法。有哈希地址冲突时,只需插入对应链表中就行。

5.进程和线程分别是什么?进程和线程的区别

进程就是系统中运行的一个程序,是进行资源分配和调度的基本单位,进程是线程的容器。

线程是操作系统进行运算调度的基本单元。

进程有独立的地址空间,一个进程崩溃在保护模式下不会对其它进程产生影响。

线程有自己的堆栈和局部变量,没有独立的地址空间,一个线程死掉相当于整个进程死掉。

所以多进程要比多线程程序健壮,但进程切换耗费资源大,效率差。对于一些要同时执行又要共享变量的并发操作,只能用线程。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值