在六月份的时候,水友就跟我说想跳槽了,一直待在传统公司不是办法,当时准备了两个月终于拿到了华为的Offer,一起感受下大佬的面试经历吧!
211本,985渣硕,毕业之后一直在传统企业。从6月底开始硬着头皮看题 ,然后从8月底开始准备秋招,到目前收获了几个offer,准备就签华为了。
京东是第一个面试的公司,虽然过了,但是京东那成海了,估计捞不起来了。
问本科做的什么,有没有学过计算机相关课程
Spring是怎么识别http请求找到对应的controller的
对象在堆内存里面会不会有移动
Integer能不能用==判断相等(-128到127有缓存)
重写equels为什么要重写hashcode(回答因为有一些需要用到hashcode的场景,比如set,会先判断hashcode是否相同,再通过equals来判断)
JVM常见的垃圾回收算法以及都有什么缺点
new一个object对象,然后再赋值给一个静态变量,然后问这个过程在JVM内存是什么个过程(回答会把创建的实例对象放到堆内存区域,然后再把指向对象的内存地址赋值给符号引用,让这个符号引用指向对应的堆内存区域)
这个对象的堆内存地址会不会发生改变(会,因为垃圾回收会对对象进行转移,比如复制法和标记整理)
输入URL到浏览器,整个过程是怎么样的
Spring是怎么处理HTTP请求的
前置分发器 DispatcherServlet 接收到 HTTP 请求之后,将查找适当的控制器 Controller 来处理请求,它通过解析 HTTP 请求的 URL 获得 URI,再根据该 URI 从处理器映射 HandlerMapping 当中获得该请求对应的处理器 Handler 和处理器拦截器 HandlerInterceptor,最后以 HandlerExecutionChain 形式返回。
前置分发器 DispatcherServlet 根据获得的处理器 Handler 选择合适的适配器 HandlerAdapter。如果成功获得适配器 HandlerAdapter,在调用处理器 Handler 之前其拦截器的方法 preHandler() 优先执行。
方法 preHandler() 提取 HTTP 请求中的数据填充到处理器 Handler 的入参当中,然后开始调用处理器 Handler(即控制器 Controller)相关方法。
控制器 Controller 执行完成之后,向前置分发器 DispatcherServlet 返回一个模型与视图名对象 ModelAndView 。
前置分发器 DispatchServlet 根据模型与视图名对象 ModelAndView 选择适合的视图解析器 ViewResolver,前提该视图解析器必须已经注册至 Spring IOC 容器当中。
视图解析器 ViewResolver 将根据 ModelAndView 里面指定的视图名称获得特定的视图 View。
前置分发器 DispatchServlet 将模型数据填充进视图当中,然后将渲染结果返回给客户端。
HTTP报文的格式是怎么样的(请求行,请求头,空行,请求体)
cookie存在http哪儿
cookie和session的区别
mysql里面的索引类型以及联合索引的最左原则
了解过覆盖索引吗(没有了解)
如果一个索引包含(或覆盖)所有需要查询的字段的值,称为‘覆盖索引’。即只需扫描索引而无须回表。 只扫描索引而无需回表的优点: 1.索引条目通常远小于数据行大小,只需要读取索引,则mysql会极大地减少数据访问量。 2.因为索引是按照列值顺序存储的,所以对于IO密集的范围查找会比随机从磁盘读取每一行数据的IO少很多。 3.一些存储引擎如myisam在内存中只缓存索引,数据则依赖于操作系统来缓存,因此要访问数据需要一次系统调用 4.innodb的聚簇索引,覆盖索引对innodb表特别有用。(innodb的二级索引在叶子节点中保存了行的主键值,所以如果二级主键能够覆盖查询,则可以避免对主键索引的二次查询)
覆盖索引必须要存储索引列的值,而哈希索引、空间索引和全文索引不存储索引列的值,所以mysql只能用B-tree索引做覆盖索引。
事务是怎么实现的。
MVCC知道吗
事务隔离级别,分别能解决什么问题
说一下什么是线程安全问题
sychronized和Lock的区别
synchronized使用的方法以及底层原理
同步方法是隐式的。一个同步方***在运行时常量池中的method_info结构体中存放ACC_SYNCHRONIZED标识符。当一个线程访问方法时,会去检查是否存在ACC_SYNCHRONIZED标识,如果存在,则先要获得对应的monitor锁,然后执行方法。当方法执行结束(不管是正常return还是抛出异常)都会释放对应的monitor锁。如果此时有其他线程也想要访问这个方法时,会因得不到monitor锁而阻塞。当同步方法中抛出异常且方法内没有捕获,则在向外抛出时会先释放已获得的monitor锁
lock的实现方法以及底层原理(CAS volatile然后AQS,然后独占锁和共享锁)
线程池参数
场景题,核心线程数6,最大线程数10,队列无界,然后说一下过程。(由于无界队列,所以线程池中的线程数不会超过6,等待队列里的任务只能等待线程处理完任务后再来执行,从头说到饱和策略)
双亲委派模型了解吗(巴拉巴拉)
怎么破坏(自己实现classloader,然后重写classload方法,然后扯到Tomcat,然后问Tomcat为什么要这样做,真想给自己一巴掌,话真多)
反问,问面试官是哪个部门的,都是做什么的。
问有offer吗(没有)
1.问项目
2.问java基础
3.问redis
4.sql删除重复数据,保留一个
delete from table where sex = (select sex from table group by sex having count(*) > 1)这是删除所有
Delete from table where id not in (select min(id) as id from table group by sex)
5.hashmap的原理
6.线程安全的本质,怎么保证线程安全
7.是什么时候学的java
8.反问
互斥条件(不可剥夺条件,请求和保持条件,循环等待条件)
-有序的二维数组查找
-LRU+TTL
主要就问了有哪些offer,打算去哪,有没有女朋啊和一些技术问题的概念解释。
1.自我介绍
2.面向对象的设计原则,单一职责原则,开闭原则(怎么实现)
3.设计模式,你熟悉的(模板模式,代理模式,工厂模式,单例模式)
4.中间件(redis,kafka)
5.mysql语句,查询一个字段,用某个字段排序,显示某一页多少个内容
6.算法题:拼单词,字符可以能拼出哪些单词。
1.自我介绍
2.深挖项目(微众银行的比赛,选择标准,取得成绩的标准,你是负责干什么的,团队分工,团队是否有分歧,怎么解决的,项目有没有遇到什么问题,怎么解决的,如果你这个东西要商用的话,还需要怎么改进,有没有考虑过安全问题,怎么判断恶意访问)
3.问了科研项目,有没有遇到什么问题,遇到最困难的问题是什么,怎么解决的,有没有看过源码。
4.反问(问了部门组成,以及连接与协同是做什么的(物联网))
当时在字节和京东直接犹豫了很久,最后还是选择了华为
1.自我介绍
2.聊项目
3.手撕mysql,查询点播量最高的视频
select viod_name from table order by times desc limit 0,1
4.mysql,查询点播最高的用户
select userid,count(*) as times from table group by userid order by times desc limit 0,1
5.redis的数据结构,redis的性能为什么好
6.redis的过期机制和内存淘汰策略
7.redis持久化的方式(没答出来)
8.redis并发问题(没答出来,两个用户同时修改一个key)
9.redis lru是怎么实现的。(通过链表实现的)
10.java的集合,concurrenthashmap怎么解决并发问题的,Hashtable怎么解决的。
11.常用的垃圾回收算法(parralell)
12.cms怎么解决内存碎片的问题(full gc)
增大Xmx或者减少Xmn
在应用访问量最低的时候,在程序中主动调用System.gc(),比如每天凌晨。
在应用启动并完成所有初始化工作后,主动调用System.gc(),它可以将初始化的数据压缩到一个单独的chunk中,以腾出更多的连续内存空间给新生代晋升使用。
降低-XX:CMSInitiatingOccupancyFraction参数以提早执行CMSGC动作,虽然CMSGC不会进行内存碎片的压缩整理,但它会合并老生代中相邻的free空间。这样就可以容纳更多的新生代晋升行为。
13.mysql建立索引的原则
14.四次挥手的过程和状态
15.算法题:求两个String类型的整形加法String num1 = "123";String num1 = "456";相加然后反转
1.自我介绍
2.说一下项目里面的具体做什么的,怎么保存在线观看的人数
3.mysql大表优化
4.有用过哪些redis命令吗(没有)
5.数据库里面都有什么表
6.项目里面实现最难的功能是什么
7.进程和线程的区别
8.为什么进程切换慢,线程切换快
9.怎么实现多线程
10.线程池都有什么,怎么创建,线程池参数,有用过线程池吗(没有)
11.线程都有哪些状态,怎么让线程进入阻塞状态,阻塞,非阻塞,同步和异步的区别
12.JVM内存模型
13.算法题
两个链表相加,1-2-3-4-5,1-2-3-4结果就是1-3-5-7-9
两个线程交替打印奇数和偶数(说了想法,没有写)
14.最近在看什么书吗,有没有接触过什么新技术
15.有offer吗
后面没收到任何通知,凉凉。这么简单的算法题,当时那面试官一脸看弱鸡的表情,给我整怕了,没写好,虽然写出来了。
天道酬勤,虽然准备晚了,但是努力就会有好结果,中间也有迷茫,也有失落,但是硬着头皮在2个月不到的时间刷了400道左右的题目。
当然最重要的一点就是坚持,不要放弃。船到桥头自然直。柳暗花明又一村。offer总会有的,不要妄自菲薄。坚持才会胜利,冲鸭!!!
最后把面试资料100%免费分享给大家,也帮大家都能升职加薪!
资料领取:戳这里免费领取,暗号:CSDN
爱编程,爱分享,听说点赞+关注的都进大厂了哦!!!