快手Java开发实习面经

总共三面,两面技术,一面hr,以分块知识写的面经:

计算机网络:

  • TCP/IP五层结构及其相应的功能
  • 交换机是几层设备
  • 链路层通过什么访问主机
  • 链路层的差错检测有哪措施
  • 网络层的路由算法有哪些,简述RIP,OSPF过程
  • 简述ARP协议过程,是如何通过IP地址获取MAC地址的
  • ping命令所使用的协议是什么(ICMP),简述其过程
  • TCP如何保证可靠传输
  • TCP的流量控制,当接收方的接收窗口为0的时候该怎么办
  • TCP的拥塞控制(慢启动,拥塞避免,超时间间隔传输及其快速重传,快速恢复)
  • 流量控制和拥塞控制有什么区别
  • TCP的连接管理中可能出现的攻击漏洞(洪泛攻击,自顶向下那本书有讲到)
  • 应用层有哪些常见协议

HTTP

  • HTTP状态码类型有哪些,及其作用
  • HTTP方法有哪些,及其作用
  • 幂等性了解过吗,有哪些HTTP方法是幂等性的,为什么
  • GET和POST的区别
  • HTTP1.0 HTTP1.1 HTTP2.0,这三个有什么区别及其改进
  • HTTP如何实现状态化,cookie被禁用了怎么办(URL重写)
  • HTTP有哪些问题,加密算法有哪些,针对不同加密方式可能产生的问题,及其HTTPS是如何保证安全传输的(对称加密+非对称加密+数字证书)

数据结构

  • 链表和数组的区别及其相应的复杂度
  • 队列和栈的区别
  • 二叉搜索树和平衡二叉树有什么关系,强平衡二叉树(AVL树)和弱平衡二叉树(红黑树)有什么区别,及其代表数据结构
  • 图的遍历算法(dfs,bfs),最小生成树的算法,最短路径的算法及简述其思想

设计模式

  • 设计模式有哪些大类,及熟悉其中哪些设计模式
  • 在平时看源码过程中有哪些源码使用到了设计模式(这个问题范围很广,我从并发、IO、集合框架、SSM方面一个个答,答到Spring的时候被面试官打住,说可以了...)
  • 项目中用到哪些设计模式,简述代理模式,策略模式和状态模式

数据库

  • MySQL的MyISAM和Innodb的区别(从事务,锁,B+树索引,读写性能方面分析)
  • Innodb的B+树索引和MyISAM的B+树索引的结构区别
  • 为什么索引能够提升性能(可以从B+树结构方面分析)
  • B树和B+树的区别,为什么MySQL要使用B+树(磁盘和树高方面答)
  • count(*)和count(1)的区别
  • MySQL的主备模式

JavaNIO

  • NIO和IO的区别
  • Selector工作过程,为什么说他是非阻塞的(select方法是阻塞的,但是注册的描述符不是阻塞的)
  • epoll和poll的区别,及其应用场景(因为Selector用到了Reactor模型,所以又提到了select,poll,epoll)

Java并发

  • 中断机制,isInterrupted和interrupted的区别,哪些状态可以中断并抛出InterruptedException
  • sleep和wait的区别
  • sychronized和ReentrantLock的区别(其中有个异常机制的区别没答上来)
  • 为什么ReentrantLock的锁粒度小,sychronized不是也可以用方法块来降低锁粒度
  • 公平锁和非公平锁的定义,及其优缺点,ReentrantLock和synchronized使用公平还是非公平锁
  • sychronized的自旋锁、偏向锁、轻量级锁、重量级锁,分别介绍和联系(膨胀)
  • 简述线程池原理,FixedThreadPool用的阻塞队列是什么
  • 简述AQS,及其核心组件,哪些地方用到AQS,用到什么设计模式(这个上面设计模式也提到,模板设计方法)
  • JUC包的CountDownLatch,CyclicBarrier,ForkJoin并发工具
  • volatile关键字,他是如何保证可见性,有序性
  • Java内存模型的可见性,原子性,有序性,用什么方法来分别保证这些特性
  • atomic包,其底层原理
  • CAS操作,及其可能带来问题和可以怎么解决(ABA问题用版本号来解决,自旋时n间过长问题可以通过上次自旋时间来进行判断)

Java集合框架

好吧,这块其实应该是属于并发的部分,因为原生的hashmap,treemap都没问,问的是juc的提供的并发集合

  • ConcurrentLinkedQueue出入队如何不并发控制会产生什么问题,讲述出入对的CAS操作
  • ConcurrentHashMap如何保证线程安全,并发度大小,jdk1.8有什么变化

手撕算法

  • 一道概率题(这个我真的忘了,这几天看的概率题很多,搅浑了。。。而且当时憋了半天不会,实在垃圾)
  • 最大子段和(dp)
  • 归并链表,并且去重
  • 堆排
  • 寻找两个有序数组的中位数,时间复杂度要求是log(m+n),用二分做

上面除了第一道不清楚外,其他都是leetcode原题。

#面经##实习##Java工程师##快手#
全部评论
群除我佬
2
送花
回复
分享
发布于 2019-04-17 12:08
这些问题也太复杂了..至于吗这么难了..
1
送花
回复
分享
发布于 2019-04-17 19:29
网易互娱
校招火热招聘中
官网直投
为啥这么难
1
送花
回复
分享
发布于 2020-02-25 20:39
太强了吧
点赞
送花
回复
分享
发布于 2019-04-17 11:33
强啊
点赞
送花
回复
分享
发布于 2019-04-17 11:48
你就两面啊?
点赞
送花
回复
分享
发布于 2019-04-17 11:53
老铁6啊,我的问题都贼简单,没你这个厉害。。。你口头offer是你自己打电话问的,还是她打给你的?
点赞
送花
回复
分享
发布于 2019-04-17 12:53
这问题也太多了吧,,,
点赞
送花
回复
分享
发布于 2019-04-17 13:30
楼主是哪个部门啊
点赞
送花
回复
分享
发布于 2019-04-17 14:41
这是你总结的还是被问到的
点赞
送花
回复
分享
发布于 2019-04-17 14:43
还有就是您几号笔试的
点赞
送花
回复
分享
发布于 2019-04-17 14:45
有点厉害啊
点赞
送花
回复
分享
发布于 2019-04-17 15:04
你是计算机专业的吗,或者你简历写的你熟悉计网吗,你这计网问的太深了
点赞
送花
回复
分享
发布于 2019-04-17 15:22
你简历是怎么写的,熟悉计网,数据结构,操作系统?我面试都是问分布式,高并发😅
点赞
送花
回复
分享
发布于 2019-04-17 16:22
emm,大佬计网问的挺全的,不过HTTP中POST方法是非幂等的。
点赞
送花
回复
分享
发布于 2019-04-17 16:33
算法和数据结构还算简单,其他都不会,我太菜了😢
点赞
送花
回复
分享
发布于 2019-04-17 20:31
问得很深很广,很有水平
点赞
送花
回复
分享
发布于 2019-04-18 09:10
牛批!
点赞
送花
回复
分享
发布于 2019-04-18 20:57
同学你是加了HR微信嘛
点赞
送花
回复
分享
发布于 2019-04-24 19:24
好厉害... 面了三轮没后续了...  看来是凉了...  膜拜下大佬..  
点赞
送花
回复
分享
发布于 2019-04-27 13:45

相关推荐

面完汗流浃背,感觉过不了了,看面经吧1.说说你平时是怎么送餐的?直接傻瓜式回答拧车把就走了2.如果送餐途中下雨了,你会怎么办?回答找个地方躲着,然后就问我那订单超时怎么办,答不出来。。3.如果有个地方爆单,同时有多个不同楼层但是是同一栋楼的地方下单,可能是什么情况?答不出来,乱蒙了个可能在开派对,有没有大佬知道的4.如果到了商家,但商家还没把餐备好,你会怎么做?直接回答干等着了,然后感觉这样回答不太好,又补了句我可能会催催商家。。5.实际送餐过程中有没有考虑过使用多部手机?我说配送账号就一个,没必要使用多部手机。面试官好像不太满意6.送到餐了,但客户一直不来取餐,你会怎么办?阻塞等待吗?我说会打电话催促客户,客户一直不来的话就把餐放到地点,然后拍照走人,然后问我这样做有没有考虑过外卖丢失的情况,外卖丢失怎么办,完了,又掉进坑了7.有没有送错餐的情况?我说实际没遇过这种场景,面试官又不太满意了。。。搞不懂,一定要有实际解决过出错的经验吗。。。没出错不是更好吗。。.8.餐箱满了,但你又接单了,餐箱放不下了,出现了OutOf Box,如何解决?我说一般我会每次接单前检查下餐箱容量,有空间才会接新的单,又追这样会不会影响接单效率,如果被其它骑手抢单了怎么办?完了,又又掉进坑了。。。9.送餐过程有没有把外卖进行分类?我说我一般电动车前后有两个餐箱,前面放带有汤水易撒的,后面放比较干的外卖。总算是能答出一题了10.看了下我送的最快的一单,问我为什么那一单10s就送达了。因为客户就在店里面,当堂点外卖是为了用券。。。我这个订单是不是有点水了,但鼠鼠是真没什么订单拿得出手了做了道算法,一道贪心,给定单子信息,寻找最短配送路线,之前刷过,10分钟a出来了 #你的简历改到第几版了# #24届软开秋招面试经验大赏# #第一次面试# #我发现了面试通关密码# #最后再改一次简历#
点赞 评论 收藏
转发
一面(48分钟)1.自我介绍2.实习经历最大的挑战3.你学过,用过哪些设计模式4.策略模式的好处在哪,策略模式是如何做到开闭原则的5.介绍一下代理模式6.代理模式和装饰器模式有什么区别,差异点在哪7.项目相关8.多线程,线程池创建的参数9.阻塞队列有啥注意事项10.为什么核心线程满了任务先进阻塞队列,等队列满了才去拉救急线程,这种设计是为什么11.Java线程安全?加锁?加锁有哪些方式?有哪些锁?12.公平锁和非公平锁有什么区别?分别是什么场景使用?13.synchronized加锁或者AQS锁底层实现,随便讲一个都行14.了解过一些并发工具或者包吗(面试官想让我说CountDownLatch,Semaphore这些的,我以为是ConcurrentHashMap那些线程安全集合)15.HashMap的扩容机制,为什么是2倍扩容?16.ConcurrentHashMap如何保证线程安全17.算法:二叉树的蛇型层序遍历二面(43分钟)1.自我介绍2.实习做的项目介绍3.ThreadLocal底层实现4.ThreadLocal内存泄漏5.哪些对象会被垃圾回收6.垃圾回收算法7.创建线程池的参数8.Mysql使用的引擎innodb9.事务特性及对应的实现10.算法:删除链表重复节点2(只保留出现值一次的节点)Hr面(10分钟)1.自我介绍2.之前实习工作地点?有无转正3.目前在面哪些公司,大概都是什么进度4.对城市有没有要求5.有没有考虑过考研6.什么时候可以来实习7.可以实习多久8.反问:什么时候出结果(下周,会在五一前)9.部门分配,由一二面面试官来决定具体分配到哪个部门做什么业务更新:流程终止!看着其他人都状态改变了,自己还是在面试中,终于,还是流程结束了,可能有缘无份吧!
点赞 评论 收藏
转发
50 643 评论
分享
牛客网
牛客企业服务