qq浏览器客户端开发一二面面经
投的后台,看到在成都就接受面了,结果二面问的问题感觉偏前端太折磨
3.8一面(1H)
很多情景问题
自我介绍
TCP和udp 区别,为什么tcp是可靠的?为什么udp不可靠?tcp为什么是可靠的?怎么实现可靠的?那你可靠的意思,我们游戏都是用udp传的,那一部分损失的udp就不管了吗?
拥塞控制是怎么控制的?他们两个算法具体过程是怎么样的?
Http和https区别?
Https为什么安全?建立连接以后传数据是对称加密还是非对称?密钥和公钥哪个用来加密哪个用来解密?那客户端和服务器哪一条线就不需要加密了吗?
MySQL 索引的数据结构?为什么用b➕树?
项目中的LRU算法是怎样实现的?你设置这个缓存最大值是多少?依据是什么?
Hashmap是怎么实现的?为什么用红黑树?
举一个死锁的情景?
怎么避免死锁?刚刚那种死锁情况怎么用Java解决?
多表多线程查询的线程池参数?
Java 自带三种线程池的使用场景?
你的线程池核心数是多少?为什么设这么多?
为什么是n+1的依据?
假设我现在要用多线程对一个数做加法,怎么保证他最后结果正确?如果不用加锁怎么实现?不用信号量怎么实现?
Volatile有什么特点?当一个线程读到后,另一个线程修改了以后,第一个线程是重新读还是他线程里面的数自己改变?
假如我要传一个大文件,传输过程中中断了,我要怎么实现断点续传?断点续传的原理?
你项目中遇到的难点?怎么解决的?怎么排查出来的问题?
假如我有一张图片要加载到内存,他的大小会不会变小?不谈微信的显示原图,就我们自己实现一个程序,不去压缩图片,会不会变小?为什么?
你平时都在实验室吗?会捣鼓一些其他小东西吗?对其他语言了解吗?c++和kotlin了解吗?
算法题:一个二叉树,只有一个数出现一次,其他数都出现两次,返回这个出现一次的数。
用面呗的ide,会自动补全,貌似里面装了gpt,只补全正在敲的类。然后自己定义树的结构,算法写出来不用写例子跑。
讲一下你这个算法解题的思想?这个位运算为什么可以得到结果?
反问
3.12二面(全是情景)
自我介绍
哪些情景下用tcp哪些情景下用udp?
tsl认证的过程?密钥私钥怎么生成的?
两个线程都需要两个锁?怎么保证他们不形成死锁?具体的Java实现方法?
断点续传的原理?每一个分片都传了一部分,怎么判断接下来要传哪些?我传100M的数据,怎么来实现断点续传?
虚拟内存是什么?有什么好处?
你的项目中怎么评估能负载多少个摄像头给你传视频,如果有很多个摄像头,你怎么去做拓展?
为什么不实时的去传视频到服务器?
有没有了解过负载均衡?怎么去实现?
#腾讯#