JAVA面经复习(四)

JAVA面经复习(四)

问:进程,线程和协程?

答:进程是计算机资源分配的最小单位,一个进程可以拥有多个线程;线程则是CPU调度的最小单位;协程又称为微线程,是一种用户态级别的轻线程,拥有自己的寄存器上下文和栈,因为子程序切换不是线程切换,而是由程序自身控制,因此,没有线程切换的开销,和多线程比,线程数量越多,协程的性能优势就越明显。因为只有一个线程,也不存在同时写变量冲突,在协程中控制共享资源不加锁,只需要判断状态就好了,所以执行效率比多线程高很多。

问:进程切换的过程?

答:操作系统为了控制进程的执行,必须有能力挂起正在CPU上运行的进程,并恢复以前挂起的某个进程的执行,这种行为被称为进程切换,任务切换或上下文切换。进程切换主要有以下四个步骤:
1.决定是否作上下文切换以及是否允许作上下文切换。
2.保存当前执行进程的上下文。
3.使用进程调度算法,选择一处于就绪状态的进程。
4.恢复或装配所选进程的上下文,将CPU控制权交到所选进程手中。

问:redis存储在内存中如何实现快照?

答:1.Redis使用fork函数复制一份当前进程(父进程)的副本(子进程)
2.父进程继续接收并处理客户端发来的命令,而子进程开始将内存中的数据写入硬盘中的临时文件;
3.当子进程写入完所有数据后会用该临时文件替换旧的 RDB 文件,至此一次快照操作完成。

问:redis存储在磁盘中,如何确保操作一致性?

答:对于读操作,不存在一致性问题;对于写操作,一般采用缓存淘汰的机制,即修改数据库中的数据,同时删除掉缓存中的数据。从而实现数据的一致性。同时依据两个事件的先后顺序又可以分成1-先淘汰缓存后更新数据库;2-先更新数据库后淘汰缓存。异步更新缓存和

问:简要介绍TCP和UDP?

答:TCP是面向传输的协议,在首发数据时要确保数据的可靠传输。因此TCP建立连接要经过三次握手,释放连接则要经过四次挥手的过程。UDP是一个非连接的协议,传输数据之前源端和终端不建立连接, 当它想传送时就简单地去抓取来自应用程序的数据,并尽可能快地把它扔到网络上。UDP使用尽最大努力交付,即不保证可靠交付, 因此主机不需要维持复杂的链接状态表

问:补码,反码,原码,移码?

答:正数情况下,原反补码相同。原码指十进制数对应的二进制值;负数情况下,反码则是原码的基础上各位取反;而负数的移码则是对十进制的值加上了一个偏移值offset,使得原值在数轴上移动了offset个单位;补码则是通过取模运算取得的负数原码的补值,常见的计算方式为原码取反+1;

为什么要用B+树,B+树有什么优点?

答:Mysql由于是关系型数据库,那么类似的数据大多是相邻存储的,因此在查询一个区间内的数据时,B+树可以对叶子节点进行顺序访问从而减少查找的时间。其次是B+树的分支节点不存储数据,因此查询效率比较稳定。

Cookie和Session的区别,如果没有Cookie会怎么样?

答:Cookie是在客户端和服务器端间来回传输的一个用于保存用户登录信息的数据包,其对应于一个特定的链接用户;而Session则是存储在服务器端的,用来标识一次特定会话信息的数据包,其会随着会话的断开链接而消失。没有cookie的话,正常情况下也不会影响网页浏览器的访问,只是客户端不能实现一些自动登录的功能,因为服务器端没法判断两次会话的链接登录是不是同一个人。

参考资料:
字节基础架构-内推成功
进程、线程、协程三者之间的联系与区别

全部评论

相关推荐

点赞 收藏 评论
分享
牛客网
牛客企业服务