1.堆为什么比栈效率低
栈申请的速度快
存储寻址速度快
CPU硬件操作速度快,CPU有专门的寄存器操作栈,而堆使用间接寻址,所以栈快。
2.二叉树使用来干什么的
常用来实现二叉查找树(用于搜索和动态排序)和二叉堆(快速获取集合最值)
3.红黑树了解吗?使用来干什么的。
①C++中map和set都是红黑树实现的。
②也用于实现Linux操作系统的CPU调度。
4.说说哈希表,如何避免哈希冲突?
哈希表可以实现常数时间复杂度的查找。
通过键值对实现,键和值一一对应。
用哈希函数获取键值对的哈希值,对应数组下标。
避免哈希冲突:
①开放地址法。有哈希冲突,将数据插到下一个位置,若还有,一直往下走直到能插入。
②二次探测法。有哈希冲突时,下次插入位置为当前位置加n的二次方。
③链地址法。有哈希地址冲突时,只需插入对应链表中就行。
5.进程和线程分别是什么?进程和线程的区别
进程就是系统中运行的一个程序,是进行资源分配和调度的基本单位,进程是线程的容器。
线程是操作系统进行运算调度的基本单元。
进程有独立的地址空间,一个进程崩溃在保护模式下不会对其它进程产生影响。
线程有自己的堆栈和局部变量,没有独立的地址空间,一个线程死掉相当于整个进程死掉。
所以多进程要比多线程程序健壮,但进程切换耗费资源大,效率差。对于一些要同时执行又要共享变量的并发操作,只能用线程。