潜了这么久水,回馈一下牛客
许愿爱奇艺!
大三双非一本
爱奇艺上海java实习生
面试官是个超级温柔和善的男生
大概总结一下这次面试问题
hashmap讲一下 resize做了啥
扩充,重新计算位置
ArrayList和LinkedList讲一下
数组/链表
讲一下spring,springmvc,springboot(概述,常用注解)
spring IOC,AOP
依赖反转和面向切面编程
AOP原理
静态代理和动态代理讲一下
java反射讲一下
java序列化
将类映射为字符串
lock和synchronized区别
ACID讲一下
事务的性质
脏读,不可重复读,幻读
MVCC,CAS
ABA问题,解决
乐观锁,悲观锁,行锁读写锁,表锁
讲一下Redis
JVM分区
堆区,方法区,本地栈,虚拟机栈,程序计数器
垃圾回收讲一下
对象是否存活
垃圾回收俩次标记(忘了。。。)
讲一下JMM
happens-before,举个例子
分布式消息队列之类的我都没有深入学习,面试官也没问啥
1.进程与线程的区别,听说过协程吗?说一说。
2.redis数据库的数据结构有哪几种。
3.TCP和UDP的区别。
4.TCP如何保证可靠性传输。
校验和,序列号,滑动窗口,接收确认,超时重传
5.TCP传输中的流量控制和传输控制,拥塞控制。
6.逻辑地址和物理地址的区别,如何寻址?
7.逻辑地址空间布局,具体有哪些部分
8.虚拟内存相关内容(快表机构等)
9.在函数中定义的变量存在哪里,malloc申请的是哪里的地址。
10.Mysql数据库两种索引的区别。
聚集索引和非聚集索引
11.听说过leveldb吗
12.select和epoll的区别,说一说底层实现原理。
自己状态不是很好,这些题答的也都不怎么样,问到这里面试官感觉也逐渐失去了兴趣,就开始写题:
1. 3x7的表格,从左上到右下,每次只能往右或者往下走一格,有几种同的走法?
2. 写一下快排。(写完之后面试官问几种排序时间复杂度,稳定性等,最后问有没有O(n)的排序(除了bitmap那种有特定条件的))
3. a b c 三个布尔型变量,至少两个为真的时候返回true,否则返回false,要求一句语句。
回馈牛客(java面经总结)
经过7月到8月的秋招提前批奋战,在牛客众多招聘信息和内推信息的帮助下,笔者成功拿下一些offer,整理了一下面试过程,希望能给大家一点帮助(笔者java方向)。
@author: NPawn
JAVA基础
JVM
- jvm分区模型
- 首先是模型分成哪几块,堆 栈等等。。
- 哪些是线程私有的哪些是共有的
- 1.6之前和现在1.8哪些地方做了改动(主要是静态区的变化)
方法区/元空间
- 垃圾回收
- 三种回收算法
- 常见的垃圾回收器
- root引用和引用计数
- 频繁GC的原因和解决方案
- 高并发后台怎么优化GC,我主要是说了调整eden和surival的比例啥啥啥的
- 类加载器
- 双亲委任
- 如果发生了冲突,会出现什么情况-- 编译不报错,运行调用bootstrapclassloader加载rt.jar中的类
- jvm调优
- 加分项,美团面试的时候一面和面试官讨论了调优的一些细节 --xmns啥的
- jvm工具,jstack jconsole 这些,还是看一丢丢,留个印象
java知识点
- 常用类型
- Hashmap 源码级掌握,扩容,红黑树,最小树化容量,hash冲突解决,有些面试官会提出发自灵魂的审问,比如为什么是红黑树,别的树不可以吗;为什么8的时候树化,4不可以吗,等等
- concureentHashMap,段锁,如何分段,和hashmap在hash上的区别,性能,等等
- HashTable ,同步锁,这块可能会问你synchronized关键字 1.6之后提升了什么,怎么提升的这些
- ArrayList 优势,扩容,什么时候用
- LinkedList 优势,什么时候用,和arraylist的区别 等等
- HashSet,TreeMap
- 基本类型和包装类型的区别,涉及自动装箱和拆箱,怎么做的,原理
- &和&&区别
- 别的一些需要注意的点
- String ,StringBuffer,StringBuilder哪个是安全的,我就说反过。。
- 字符串编码的区别,被问到过,我觉得比较容易被忽视的一个点
- 什么是泛型,怎么用泛型
- static能不能修饰threadLocal,为什么,这道题我当时一听到其实挺懵逼的
- Comparable和Comparator接口是干什么的,其区别
- 多态的原理是什么,感觉这个很容易被问到
- 接口和抽象类,面试官问我是怎么理解的,我说接口对应功能,抽象类对应属性,然后面试官给我说了他的看法,说抽象类更偏向于一种模板~ 然后又交流了一下各自的想法
- 如何通过反射和设置对象私有字段的值
- 快速失败(fail-fast)和安全失败(fail-safe)的区别是什么
- List,Map,Set接口在取元素师,各有什么特点
- java并发
- 线程的实现方式——runnable thread future
- 如何线程安全的实现一个计数器
- 生产者消费者模式,要求手写过代码,还是要知道的
- 单例模式,饿汉式,懒汉式,线程安全的做法,两次判断instance是否为空,每次判断的作用是什么。
- 线程池,这个还是很重要的,在生产中用的挺多,四个线程池类型,其参数,参数的理解很重要,corepoolSize怎么设置,maxpoolsize怎么设置,keep-alive各种的,和美团面试官探讨过阻塞队列在生产中的设置,他说他一般设置为0,防止用户阻塞
- cyclicbarrier 和countdownlatch的区别,个人理解 赛马和点火箭
- 线程回调,这块 被问过让我设计一个RPC,怎么实现,其实用到了回调这块的东西
- 线程的几种状态
- 六种
- sleep 和yeild方法有什么区别
- volatile关键字,可见性。
- 锁
- 乐观锁和悲观锁的使用场景
- 悲观锁的常见实现方式:lock synchronized retreentlock
- 乐观锁:CAS MVCC
- 读写锁的实现方式,16位int的前八位和后八位分别作为读锁和写锁的标志位
- 自旋锁
- 死锁的条件,怎么解除死锁,怎么观测死锁。
- 大数
- 我觉得这个点是我在面试中,被问到的比较不会的一个点
- 题目是这样的:在java中,0.000000001 和0其实是判定相等的,那么我怎么才能得到真实值呢
- bigdecimal java中的一个类,我觉得,多一些思考是比较重要的
- 反射
- 这个概念,我觉得是非常非常重要的概念,NN多的东西都可以归结为反射
- 反射的实现及原理
- 希望大家能够好好看一下反射的原理,怎么确定类,怎么调方法
- RPC框架,同步异步,响应时间,这些都被问到过,还让设计过
- IO
- 同步,异步,阻塞,非阻塞 在深信服的面试中遇到过,最好再找一些应用场景加以理解
计算机网络
- 网络概述
- 七层模型
- tcp的五层
- 常见的每层的代表协议
- TCP
- 三次握手,四次挥手
- 如果2次握手会怎么样,四次回收如果服务端直接把ack和fin一起返回做三次挥手会怎么样
- 窗口机制,你了解吗
- 如果用TCP进行服务器某端口的探测,你要怎么改tcp使得其消耗最少,面试官提示过我,tcp先发syn包,然后收到ack之后,直接回一个reset
- 如果有一台机器B,去模拟机器A,向C发送syn包,这个时候会怎么样,讲真的,我一脸懵逼。。
- TCP的原生API用过没
- socket websocket 会从tcp里面引出来
- UDP
- 和TCP的区别
- 应用场景
- ftp 怎么实现的,,,
- http
- 浏览器中输入一个url,是一个什么样的通信流程
- http1.0 和http1.1 加入了长连接 keep-alive时间怎么设置,,
- http2.0 。。。 面试的时候真的是非洲问号,,
- http中的几个方法
- https
- 加密方式
- 非对称传输秘钥,对称传输数据
- 常见的加密算法~
- 别的问题补充
- DNS寻址过程,递归~
- 负载均衡反向代理,这个时候,访问后台的那个ip到底是客户还是反向代理,还怎么统计ip?
- 还有一些新的协议
- webRTC
- http2.0
- 然后有几个面试官提的,我忘了,,
Linux
- 命令
- 常见的命令
- sed 和 awk 感觉linux必考。。
- linux的使用场景,你什么时候会用linux -- 》 布置服务器
- 怎么查看进程和杀死进程
top
ps -ef | grep xxx
kill -9 xxx
-
- 打印一个文件夹中的所有文件
- 常见计算机原理的知识点
- float在计算机中是怎么存储的,当时被问到的时候,我也在问自己,怎么存的~ 佛了
- 线程和进程的区别
- 线程的通信方式,进程的通信方式
- 系统线程的数量上限是多少
- 页式存储的概念
- 内存碎片,你有了解过吗,有想过解决方案吗~
数据库
- mysql
- 引擎,区别是什么
- 索引,有哪些索引,怎么用
- 索引为什么要用B+树,B+树和B-树的区别是什么
- mysql的默认事务级别,一共有哪些事务级别
不可重复读
-
- mysql的一些语句,这些肯定需要掌握的
- mysql事务是怎么实现的
- mysql锁,行锁,表锁 ,什么时候发生锁,怎么锁,原理
- 数据库优化,最左原则啊,水平分表,垂直分表
Spring相关
主要是配合项目进行询问,问的深度一般。看个人项目
- spring
- spring的两大特性- ioc aop,实现原理
- 如果存在A依赖B,B依赖A,那么是怎么加到IOC中去的
- beanFactory的理解,怎么加载bean
- FactoryBean的理解
- 基于注解的形式,是怎么实现的, 你知道其原理吗,说一下
- 依赖冲突,有碰到过吗,你是怎么解决的~
- bean的生命周期
- 依赖注入的几种方式
- spring中的自动装配方式
- 总之,建议大家如果时间充裕,还是好好看看源码~~
- spring mvc
- 和struct的区别
- 你一般是怎么对mvc项目进行分层的
- dispatch-servlet的工作原理
- ***怎么配置,工作原理
- 为什么有了springmvc还要在项目中使用spring?
- springmvc的运行机制,dispatch -》 hanldermapping-—》handler -》handlerAdapter-》执行handler-》modelandview -》 返回mv -》 视图解析器-》返回view -》 渲染响应
- mybatis
- 配置
- 怎么防止依赖注入
- 和hibernate相比,为什么选择mybatis
- 怎么让mapper 和xml对应
- 如何自动包装对象
- 逆向工程
- springboot
- 和spring相比,做了什么改变
- starter你知道哪些
- 如何部署springmvc项目 以及如何部署springboot项目
- springboot的插件,你使用过哪些
中间件
- redis
- 为什么选择redis,有什么好处,基于内存,抗压
- redis集群怎么进行数据分配,hash槽
- redis的主从复制是怎么实现的
- redis的数据结构 最常问 hash是什么, sorted set怎么实现的
- 因为项目的原因,问我redis是怎么保证高可用的,主从和集群怎么加在一起
- redis 和memcache的区别
- redis 分布式锁的实现原理 setNX 啥的
- redis模拟session,除了redis你还考虑过别的吗
- redis的缓存击穿,怎么处理这个问题
- redis是基于内存的,那么它有持久化吗,aof rdb
- aof和rdb的优缺点,你在项目中使用的哪一个
- redis 的淘汰算法,你在哪配置淘汰算法
- MQ
- 为什么选择rabbitMQ, 社区活跃,高并发
- 别的MQ也要了解,比如RocketMQ(阿里的,java开发,再次开发,并发高,分布式,出错少)
- ActiveMQ, kafka
- topic 和 block
- MQ的作用,同步转异步,消除峰值
- 如何保证数据一致性,即原子性,ack
- 消息队列在项目中的应用
- nginx
- 怎么配置负载均衡
- 怎么限流
- 怎么使用nginx缓存
- 为什么使用nginx,有别的替代品吗
- nginx的压力测试,你测试过吗,能抗住多少压力
- dubbo
- 原理,怎么用
- 和erueka有什么区别
- 为什么要用dubbo,不用行不行?
- 跨域请求的一些知识点
其他插件
- shiro
- 怎么做权限控制
- 为什么使用shiro,你直接使用aop不也是一样的吗,shiro还有标签~各种扯
- shiro的两个最重要的函数
- 认证和授权是怎么做的
- docker
- 和vmware的区别
- 你一般是怎么部署的 IDEA,直接把项目部署到docker并打包到云服务器
- docker的好处,小,快
算法
- 排序算法
- 八大排序算法真的是面试宠儿
- 最常考 快速排序 和归并排序
- 哪些排序算法是稳定的 哪些是不稳定的
- 堆排 也应该掌握
- 树
- 根据遍历结果恢复树,递归
- 二叉搜索树第k大
- 树的和为k的路径
- 层次遍历
- 根据层次遍历和后序遍历恢复树
- 镜像树
- 树的深度
- 是不是平衡二叉树
- 链表
- 反转链表
- 链表环的入口
- 交叉链表的交点
- 复杂链表的复制
- 二叉搜索树变成双向链表
- 回溯算法
- 走迷宫
- 游戏通关
- 递推算法
- 走台阶
- 断钢筋
- 。。。。
- 背包问题
- 装最多的东西
- 贪心算法
- 覆盖问题
- 时间问题
设计模式
面试中设计模式其实也是挺重要的
-
- 观察者模式
- 适配模式
- 工厂模式
- 等等
以上就是我在回想面试过程所能想到的一些问题,可能不够全面,仅供参考。
建议:多刷题,算法是根本,很多公司算法关是必须要过的。简历上写的项目所涉及到的知识点,必须很好的掌握,不然的话就不要往上面写。在面试的时候,如果遇到不会的问题,就说不会,不要不懂装懂,容易引起面试官的不满。
祝大家,面试顺利,早日offer。
vivo(软件研发工程师)
6.4 笔试 6.12 面试(现场面)
一面(40分钟)
- Static变量和方法有什么特点,能不能访问非静态成员,为什么
不能,对象未实例化
- Static方法能不能重写,为什么。父子类调用方法访问顺序
- 抽象类和接口的成员变量有什么差别,类访问权限
- HashSet怎么实现的,底层
- HashMap怎么遍历的
- 线性结构有哪些,二叉树属于吗?
- 二叉树最多有多少个节点?第k层有多少个节点?
- 冒泡排序怎么实现,怎么优化,两层循环各是干什么的。
- 多线程中wait和sleep方法的区别,锁
- MVC模式怎么实现,流程介绍。
- Hibernate怎么和上层交互,用过哪些数据库,了解多少。
- 手写sql:查询从6.1开始到现在每天的评论数量;评论大于1000的数量(注意日期函数)
- 说论文,说项目(具体细节不说了……)
- 项目方法是自己提出来的还是有前人做过,有什么不同,改进在哪里。
字节跳动(游戏研发工程师)
6.30 笔试 7.7 技术一二三面 7.12 hr面(都是视频面)
一面(一小时)
- 自我介绍
- 网络分层结构
- TCP为什么在网络环境不好的时候慢
需要建立连接
- 滑动窗口机制
- Google的BBR算法
- 抽象类和接口的区别
- 数据结构底层 list map arraylist hashmap
- 堆 栈 方法区的区别
- Hibernate的session
- 数据库底层
- 说项目(都是问论文,不说细节了……)
- 项目用到哪些设计模式 有帮助么
- 算法:6个或8个苹果装一个袋子,最少袋子数量 DP背包问题
- 为啥投游戏
二面(50分钟)
- 聊项目和论文……
- JAVA垃圾回收算法
- 数据库mysql和redis区别
- 并发:线程池、锁等
- 对中间件对了解
- 场景题设计:卡牌游戏数据结构 抽卡概率 十连抽必出卡 单卡概率出
- 场景题设计:游戏服务端和客户端的设计 分别考虑什么
三面(一小时)
- 了解哪些数据结构 以时间复杂度的角度说
- List Map……LinkedList如果要查询O(1)怎么设计
- 设计模式:项目里怎么做的 优化性表现
- 深挖项目(问的问题都很深,深挖底层的那种……)
- 算法:链表k段反转
- 场景题1:很大地图 每个npc移动 数据结构设计 怎么找周围的npc 算法 以圆半径怎么找 注意玩家是在移动
- 场景题2:游戏排行榜 弹幕的数据结构设计 考虑哪些因素 怎么存数据库里
- 场景题3:前100的玩家怎么找 说了分治 分治怎么做 分布式的话怎么一致……
7.12 hr面(20分钟)
- 自我介绍
- 自己的优缺点
- 学习过程中遇到的一些问题如何解决的
- 性格上的优缺点
- 家庭情况
- 为什么想来北京
字节的面试体验很好,7.23就收到意向书了,也是我很想去的厂,纠结选择中。
百度(Java研发工程师)
7.18 一面 7.19 二面 7.22 三面(都是电话面)
一面(一小时10分钟)
- 自我介绍+说项目…
- HashMap 底层数据结构
- 有序 TreeMap怎么实现 倒序呢?
- 有哪些异常 怎么处理 自己定义过异常吗
数组越界,空指针,并发访问异常
- 类加载器
- 违背双亲委派模型的例子 Tomcat
- Tomcat违背过程
- 自己写一个HashMap走双亲委派会被覆盖吗?
会
- 从浏览器传入到Tomcat处理全过程
- SpringMVC全过程
- 堆内存介绍 两个survivor频繁切换会进入老年代吗?设置阈值的参数是啥?
- Redis管道
- Redis文件持久化 会影响主进程吗
- Redis分布式锁的实现
- MySql隔离级别 怎么实现可重复读的
- 间隙锁咋实现 用sql语句说一下
- MySql索引怎么实现
- 为啥用B+树范围查询比较好?
B+ 树是一种排序树
- Mysql时间戳 怎么不修改自己增
- 算法:两个栈实现队列
- 算法:找二叉搜索树的第k小
中序遍历取第k个
- 算法:X的n次幂怎么实现
快速幂log(n)
二面(一小时)
- synchronized底层原理 在哪有应用
- 场景:银行转账 synchronized怎么实现 在哪里加锁 A和B同时互转呢 一定要同时
- wait方法 notify方法
- 线程池
- Spring 事务传播机制 基于什么实现
- 场景:事务a里调用事务b,b方法是私有的,怎么做
- Spring AOP简单说一下
- mysql联合索引,有ab两索引,a=1 order by b能做么(还有几个sql语句的场景让说索引)
- 泛型,有个list extend 数字,list可以add吗
- 场景设计:客户信息 手机号联系方式可以有1~n个,一个人可以有多个号码,新来一个客户判断是否在数据库里,比如另一个同名的人有2个号码,全部包含在第一个人里就算在,否则不算。数据库存很多个数据,怎么设计
- 设计模式 说五个以及项目里用到的
- 谈项目……
三面(一小时)
- 自我介绍
- Linux命令awk sed
- 位运算 取模用哪个
- TCP UDP HTTP 浏览器输入网址之后的流程
- 知道哪些架构 随便说一些
- 讲一下微服务SOA DDD
- CAP原理
- 说下对分布式的理解
- 毕业时间 能来实习吗 有和导师商量的余地吗
- 做过哪些大型的工程类的项目
- 做项目的过程给你带来的收获,最重要的一点
- 学习中遇到的最大困难,怎么克服的
- 科研过程中如何进行自己的课题的
- 发的论文难点 困难 怎么做的
- 为什么不考虑机器学习和大数据方向
- 对未来职业发展方向的规划和想法 矛盾
- 对来北京发展的生活压力工作压力怎么看
- 为什么想到从事技术类开发和测试,你觉得区别在哪,有考虑未来产品运营等非技术类岗吗
- 个人优缺点 多说几点
- 最近在看什么书 平时生活中喜欢看什么书
- 做什么事情会让你最有成就感
- 最近什么事让你有挫败感
- 对外界对百度的评价有什么看法,如果你之后入职百度了你会有什么想法
- 对百度什么方向的研发感兴趣 偏商业化的还是偏用户的
- 用过哪些百度app 有什么感受和建议
- 你有什么要问我的
阿里(Java研发工程师)
阿里云 7.24 一面 8.2二面 (都是电话面)10月 三四五面+hr面(视频面)
一面(一小时)
- 自我介绍
- 项目难点 遇到的最大的问题,怎么解决的。
- 输入www.baidu.com的全过程
- 自己实现服务端时,怎么处理响应 ServletRequest和ServletResponse
- 线程池怎么创建 几种线程池介绍一下
使用工厂方法
固定大小线程池
无界线程池
缓冲线程池
- 无界阻塞队列和有界阻塞队列区别 fixedThreadPool用无界队列有什么不好
- JDK版本 你用的是多少
- 介绍下集合类(Collection、Map)
- HashMap和HashTable的区别
- 介绍下ConcurrentHashMap
- switch 支持类型
- OOM遇到过吗 原因 解决方案 你遇到过哪些
- 给8G的内存 怎么设置堆的参数
- 3亿数据量 插入一条sql语句发现很慢 怎么调优
- drop delete truncate 区别 能不能回滚
- 1w个数据无序的 怎么找出前1000个最大的 有序的呢
- Spring MVC流程
二面(1个半小时)
- 项目难点 平时怎么学习看书的
- zookeeper应用场景
- 负载均衡 Nginx七层负载均衡、DNS怎么做负载
- 缓存和数据库的一致性怎么保证
- 服务器压力一样,连接过来怎么保证负载均衡,用zookeeper
- 对大数据的了解
- 算法:归并排序
- 算法:设计一个重试执行器
三面(半小时)
- short、int、long各占多少字节
- String、StringBuilder、StringBuffer的区别
- 说说Java中有哪些锁、怎么用
- int i++ 多线程怎么保证原子性 为何volatile不行
- 多线程volatile修饰变量的通信过程
- 乐观锁CAS怎么用 要用到volatile吗
- AtomicInteger的底层机制
- BIO和NIO的区别
- 怎么保证先读20k数据包,再读30k数据包的非阻塞性
- 自己写一个String类,会调用lang包的String还是自己写的
- 说说双亲委派模型
- Tomcat为什么违背双亲委派
- 算法:字符串表达式运算,带括号和加减乘除,一次遍历
- 百万级数据,怎么设计白名单和黑名单
- 布隆过滤器的hash冲突有哪些解决方法
四五面+Hr面(一个半小时)
- 深挖项目细节……
- 算法:写快排优化 看代码风格和质量
- 场景题:微信/支付宝支付为什么比银行转账快 底层做了什么优化
- 场景题:秒杀系统怎么保证快速准确的 底层服务器设计
- 平时怎么看书、爱好
- 平时怎么学习新技术
- 喜欢看哪些博客 关注点是什么
- 项目中如何解决困难
- 投了哪些公司 目前的offer
网易有道(Java研发工程师)
8.3笔试 8.16 一面 8.30 二面 9.6 三面 9.12hr面(都是视频面)
一面(40分钟)
- 常用的数据结构
- 各种链表之间的区别
- 算法:链表归并排序。递归写法和非递归写法两种
- 归并排序的难点
- 数据库 索引 什么时候不适合用
二面(80分钟)
- 算法:实现根号2,保留10位小数
牛顿迭代?
- 算法:实现一致性hash
- 一致性hash底层用的什么数据结构
- 介绍项目
- HTTP协议1.0、1.1、2.0的区别
- HTTPS协议双方确认传输密钥过程
- 场景:select name, age from user的数据库查询过程,以及怎么优化,有索引以及无索引时
- update age from user无索引是行锁还是表锁,为什么
- mvcc隔离级别怎么防止幻读
- 主从同步过程,binlog两种类型的区别
- 场景:用数据库实现分布式数据库唯一id递增
- 每个数据库缓存失效的那一刻怎么办
- 说下对dubbo、zk等分布式的理解
- 自己设计一个PRC框架要考虑什么
- 用Tomcat主要是解决什么问题
- SpringBoot了解吗
三面(30分钟)
- 怎么设计一对多关系数据表、多对多关系数据表
- 数据库第一第二第三范式
- 数据库死锁
- HTTP的get、post、delete之类
- 算法:矩阵走方格的最短路径,有障碍物(BFS)
- 设计微信发朋友圈、浏览朋友圈、删除朋友圈的整个流程和存储结构
- 说项目和论文……
- 工作岗位意向 想做哪方面
- 团队部门更喜欢哪个
腾讯(后台研发工程师)
8.12 一面 9.4 二面(均电话面) 8.15笔试
一面(一小时)
- 项目和论文介绍了半小时:很对口的面试官,感觉对我的研究方向很了解
- TCP拥塞窗口 滑动窗口
- 慢启动算法底层是怎么做的 好处坏处
- 拥塞变化的原因
- DDOS攻击 防御
- HTTP 3.0 2.0 1.0
- HTTP 2.0 服务器push怎么做的,怎么知道客户端需要哪些资源 为什么要这样做
- 给N个数找最大的K个数 算法怎么做
- 说一下堆结构的实现
二面(半小时)
- 说项目
- 慢启动算法用的哪一个 区别
- 内核源码中TCP窗口大小怎么计算的
- WIN_SCALE怎么计算
- 多个客户端窗口大小不一致 什么原因 怎么设置
- SO_RCVBUF设置的作用 仅对一个socket
- 怎么保证所有TCP连接都能有效 什么数组设置
- 内核源码角度说一下TCP三次握手
- 全连接和半连接
- TCP服务器连接过多,怎么排查
- syncookie关闭了就不能保存连接了吗
- Linux 查看网络流量 iftop
- Linux 查看TCP连接状态 netstat
- netstat参数中的Recv-Q和Send-Q什么意思,Recv-Q爆满了是什么原因
一面是秋招期间面的方向最对口的,面试官和我都觉得挺合适的,但是无奈部门在深圳,面试官说如果不接受的话后面就不继续了,没办法我真接受不了深圳只能拒绝了……后面面试官又打了两次电话确认我的意向,还是拒绝了深圳,心痛到流泪T_T
后来二面换了个部门捞,是目前面到现在最难的,感觉自己走错了片场,我真的是在面后台开发吗,太底层了,感觉自己答的很烂。当时说地点有北京,可是后面还是深圳??
后面又陆续被腾讯捞了三次都是深圳的,面试的前5分钟面试官发短信来说“看你之前的记录说不接受来深圳,我这边是深圳的部门,如果不接受我们就不面了”(现在听到深圳两个字我都发抖……)地点限制无缘腾讯了。
美团(系统开发工程师)
8.15 一面 8.23 二面(都是电话面)9.24 三面+HR面(现场面)
一面(一小时)
- 说项目
- 令牌桶算法
- 登录验证码怎么做
- Cookie和Session存在哪 如果是多机存储都会有什么问题 带id去找重复了怎么办 多用户修改了怎么办
- zookeeper数据结构 写节点的内存限制 在dubbo里作为什么角色
- dubbo中服务调用的几种形式
- RPC过程 怎么知道要调用的远程主机的方法
- 怎么把一个异步过程的返回结果转为同步的
- IOC的循环依赖 怎么解决 有哪几种
- AOP原理
- 你遇到的常见异常
- StringBuilder和StringBuffer区别
- ==和equals的区别
- HashMap、concurrentHashMap
- HTTP有哪些方法 get和post的区别
- 设计模式
- CAS实现原理
- ThreadLocal原理,底层,放在哪
- AQS实现原理 队列为啥要双向的
- Condition队列
- 平时怎么学习的
- 给你自己的技术打几分、学习能力打几分
二面(40分钟)
- TCP和UDP的区别
- TCP时间和资源消耗具体在哪
- 滑动窗口大小初始值
- TCP和UDP可以共用端口吗
- socket先启动服务器还是先三次握手 对应关系
- 三次握手过程中存在的问题
- Linux进程通信方式 最常用的哪种
- 共享内存生命周期
- Linux堆栈和Java堆栈区别
- Java线程池 ScheduledThreadPool
- 项目应用属于io密集还是cpu密集
- Spring的优点和缺点
- Bean对象作用域有哪些
- 知道什么别的类似于Spring这样的框架
- 反向代理为啥叫反向不叫正向
- Nginx和Apache 为什么Nginx快 底层实现是什么
- 数据库mysql存储引擎 innodb优势 其他引擎
- 用索引一定快吗 什么情况下查询快/慢
三面(一小时)
- 深挖项目 挨个问一遍
- 对Spring架构的理解 画类关系继承图
- 对Dubbo的理解 结构是什么样的
- 设计题:电商系统设计 画类图和UML图表示之间的负责关系
- 如果给你一个大型系统开发 如何分工统筹 按什么原则分
- 项目中和别人遇到冲突的例子 怎么解决的
- 平时为什么看源码 如何读源码 按照什么顺序学习
- 对架构设计有什么看法
- 了解领域驱动设计吗
网易游戏(游戏研发工程师)
9.7笔试 9.19 一面(视频面) 9.27 二面+HR面(现场)
一面(40分钟)
- 算法:M个元素的数组随机返回N个(M>N),等概率
这道题目和随机洗牌算法类似,只需要随机选取1个元素, 然后在剩下的元素里面随机选取下一个元素,不断这样操作即可。
这样做能保证每个元素选中的概率一样吗?也就是选中每个元素的概率都是1/n? 答案是YES,让我们来做一下简单的计算。
选第1个元素:在n个中随机选,因此概率为1/n
选第2个元素:在剩下的n-1个中随机选:1/(n-1),由于第1次没有选中它, 而是在另外n-1个中选:(n-1)/n,因此概率为:(n-1)/n * 1/(n-1) = 1/n
选第3个元素:同上:(n-1)/n * (n-2)/(n-1) * 1/(n-2) = 1/n
- 算法:实现Map的迭代元素遍历,删除一个元素
- String和StringBuilder的区别
- 各种Map介绍一下 put/get操作
- HashMap是线程安全的吗 会有什么问题
不是
- ArrayList/LinkedList 前者扩容是迭代器会有问题吗
- 说一下红黑树
- 矩阵按行遍历和按列遍历的效率一样吗
- Java内存模型
- Java如何进行内存回收
- Java 8之前的类对象可以回收吗
- 编译之后的对象放在哪
方法区
- 类加载过程
- Socket TCP的客户端和服务器的连接通信过程设计
- accept是阻塞的吗
- Socket TCP客户端和服务器的断开过程
- 出现大量的CLOSE_WAIT状态如何排查
- 操作系统的虚拟内存
- 页面置换算法 LRU用什么数据结构
链表和哈希表
- 图形学了解吗
- 玩过哪些游戏
- 场景题:进入游戏界面时大量玩家排队, 中途有玩家退出 如何设计这样的场景,用什么数据结构
- 场景题:二维地图 很多点 找离自己最近的玩家
二面(一小时)
- 算法:N个数字打印全排列(DFS)
- 深挖项目……
- Linux源码中各包的架构流程
- TCP滑动窗口的作用 人为能修改吗
- 单链表O(1)时间删除节点 思路
- 数组和链表遍历谁快 为什么
理论上数组,因为空间连续
- 进程如何访问内存空间
- Cache 用来做什么的 快表页表怎么用
- LRU算法底层实现原理 增删查时间效率
- 数据库用过哪些 大概说一下
- Redis和mysql一致性保证
- 场景题:设计聊天室服务端整体架构 画图
- 概率题:圆中随机取一点 设计思路
- 对游戏研发具体做什么的理解
- 具体要学习哪些技术 自己的了解
- 互联网加班压力自己怎么看 家人怎么看
- 投了哪些公司 offer情况
- 期望工作地点&期望薪资
HR面(20分钟)
- 大概介绍下自己的研究生课题&项目
- 会经常性地去了解新技术吗 平时怎么学习的
- 喜欢挑战性的工作还是固定一些的
- 项目中遇到的最大困难 如何解决的
- 说下自己的学习能力
- 人际交往能力怎么样 举例子
- 投了哪些公司 目前的offer
- 期望薪资
网易游戏是唯一一家北京没有工作地点报的厂,报着对游戏的情怀也要去面试hhh。第二天晚上就出结果了,给了大sp,今年网易游戏的薪资太有诚意了!
华为(通用软件开发工程师)
8.21笔试 9.20 技术一二三面(现场面)
一面(半小时)
- 算法:正整数n最少由多少个平方数组成(DP,leetcode279)
- 项目介绍……
- 论文介绍……
- 代码量 git维护
- 说下快速排序和堆排序
二面(半小时)
- 算法:替换k个字符的最长重复子串(滑动窗口,leetcode424)
- 项目介绍……
- 数据结构 树 用过哪些 区别 B+树 红黑树
三面(半小时)
- 聊人生……