互联网寒冬下,某java技术大佬面试五大厂总结!

今年互联网寒冬求职不易,这是一个技术大佬面试大厂java工程师的心得,全文接近5000余字有点长,但愿你们耐心看完,原文以下: java

已经凌晨2点多了,看来今天是失眠了,反正睡不着,写篇日记总结一下我最近面试经历吧。 程序员

2019年5月1日办理了离职手续,离开了万通中心,也算是和个人第二个东家正式说了再见,其实仍是很喜欢国贸的, 面试

这是个美妙的地方,容纳着不少金融界人才们的梦想,往往晚上走到这里你会感叹帝都的夜景好美,只惋惜这里的多数人都顾不上欣赏这里的风景, redis

每一个人都生活在压力下,成为了金钱的奴隶,但这并非什么坏事,由于他们上有老下有小,身上背负着责任,也正是他们的身体力行才造就了CBD的繁华。 算法

而我最终选择了离开这个地方。 spring

我从不否定个人离开和钱有关,这确实是其中一个因素,我也像全部人同样背负着责任,因此我须要钱,但我更想说此次的离开是为了寻求一个对我而言更大的舞台, 数据库

让本身更加快速的沉淀和成长。我曾经试图向个人领导们陈述个人价值观,我并不认为钱和理想是互斥的,难道赚的越少你的工做就越有价值么,很明显不是的。 编程

美团网 设计模式

第一个投的是美团网,去年刚上市的,发展比较迅速、美团的技术在国内也是首屈一指的。 数组

先填了一份资料,而后是就是面谈了

算法和数据结构以及架构设计方面,答的很很差,好多都忘了。

一 、本身实现一个hashMap,这个难不倒我,jdk的源码中最熟悉的就是Collection包了,使用数组和内部类完成哈希表的数据结构,

再经过hash算法和链表操做完成哈希表的插入查询等操做;

二 、并发编程中的生产者消费者模式代码,没写出来,忘记了,真是不该该哦,最简单的方式就是使用wait和notify去阻塞唤醒(这么基础的东东我都能忘),

固然还有不少优雅的写法,好比使用可重入锁(ReentrantLock),使用锁计数器(CountdownLatch)等,当时一种都没想到,自责中;

三 、字符串的一道算法题,这类小case,就是位图法,毫无压力的写出;

四.、写一个本身熟悉的架构图,因而我把个人老东家的系统架构搬了上去,简单来讲就是经过hessian将前台调用逻辑与后台业务逻辑解耦,

实体能够经过序列化和反序列化传递(这是hessian最擅长干的事情),最终提升后台业务逻辑接口的可重用性以及系统的可维护性。

还有两三道题目忘记是什么了。时间仍是很紧的,只有一个小时时间。交卷以后开始面试,一面继续聊了聊jdk的Collection包,

还有就是以前在公司所作项目的部署思想。二面就是聊聊java并发锁机制,为何要用读写锁而不用synchronized这种同步锁,事务隔离性的理解,

为何会有脏读,可重复读,提交读等,spring的事务管理是如何实现的,编程式如何实现,aop式如何实现,动态代理的原理是什么,

事务的传播性的理解。总之都是这类比较重视原理的问题,答的还能够吧,最后就是部门负责人来直接面试,谈谈为啥离职,指望薪资什么的,也聊了下技术。

问我会不会来,最后我回答我考虑一下,下周三给回复,而后就离开了。感受公司环境很好,饮料零食什么的都是免费吃。

360

第二个去的是360,没有笔试,直接面试,一面主要问基础,String内容存放在哪儿,答运行时常量池,而后我把jvm的内存结构讲了一下,

堆、栈、程序计数器、方法区、网赚博客等,每块区域的做用之类的,那么问题就来了,jvm的回收机制是什么,感受问的有点大,不知道从哪儿提及,

只好从分代回收算法提及了,从GC ROOTS的引用链机制到新生代的小空间复制算法再到老生代的标记清除算法,最后就是新生代和老生代

之间的关系以及跃迁等,随后面试官点了点头说那你再讲讲jvm的类加载机制吧,委托双亲机制吧,正准备讲,那小哥问反射机制是如何

利用类加载机制的呢,只好把反射的实现原理也balalala。。。继续发问,懂哪些设计模式,答:单例,建造者,观察者,模板方法模式,

迭代器模式balala,你在项目中用到过观察者模式吗,怎么用的。答:作统一配置组件的时候使用到了zookeeper的发布订阅,建立了监听链表,

完成应用系统的注册和同步,balalala,边写代码边讲细节,正讲的起劲,被打断,你写个单例模式吧,把你认为效率最高的单例实现写出来,

固然是经过jvm的内部类机制实现单例了,又快又安全,看完面试官点点头,说再写一个双检查的懒汉单例模式吧,好的遵命,写完后小哥发问,

为何要用volatile关键字,答:在高并发时会出现并发模式异常,volatile能够防止指令重排,建立对象操做并非一个原子操做,

分为三个步骤,balala,讲了一通,面试官被说服,随后面试官发问,能不能讲讲线程的内存模型,哈哈,幸亏之前研究线程可见性的时候研究过这个,

讲完面试官很满意,感受他已经hold不住我了(暗自自喜),谈谈你对cas的理解,答:是指乐观锁吗,还没等我说,面试官说好,你等一下,

二面面试官走了进来,开始发问,假设有一个场景,系统须要某个特定时间内响应用户请求,好比说100ms内完成用户请求,

可是www.818mulu.cn在最高峰的时候每单位时间几百万的用户请求,也就是高并发,但我必需要实现系统响应及时,并且高可用(不宕机),假如你是架构师,

你该如何架构这个系统,聊聊你的方案,当时听完脑子就蒙了,恨本身当初没去看那本《大型分布式网站架构》书,因而就开始凭感受说,

首先确定须要作缓存集群,防止数据库雪崩,数据库若是请求量很大也须要分库分表,各类乱说,说得本身都晕乎乎的,最后面试官说有的对有的不对,

并且没说到点子上,不过能够理解,你工做经验才4年。而后向我介绍了一下他们部门是作什么业务的,随后问我为何离职等,到饭点了,

我就被拉走了。次日hr打电话给了offer,聊了聊薪资待遇,360待遇不错,吃饭还免费,挺好的。

陌陌

第三个是陌陌,据说是个约炮的,哈哈哈,只是对社交软件充满了好奇,去看看,一面先写代码,写一个二叉树的深度遍历,小case,递归搞定,

随后发问memcache的内存管理机制,答:slab分块管理,最终以chunk分配,维护了一个LRU的双向列表,balabala。。。而后又问了问zookeeper的一些东东;

二面问的比较杂,大部分不记得了,居然还问vi命令,我也是跪了。

百度

第四个百度,百度今年是中止社招的,大部分部门都不社招只有校招,但也有少数部门有特批名额,因而就去试了一把,一面刚来就是写代码,

一个单链表的算法题目,写完,面试官很满意点点头,随后面试官发问在你的项目中spring是如何管理zookeeper的,答:balabala,

了解zookeeper的leader选取算法吗,讲一下他的流程,知道zab算法吗,讲一下他的流程,汗,问的问题都太变态,没想到会问的这么深,

zab算法太复杂了,zab是基于paxos的,而paxos但是得到图灵奖的算法,勉强说了一下,说的很心虚,有好多盲点本身也没搞清楚,

不过好在面试官也不往下问了,其实我估计他也不见得会(窃喜),随后让我稍等一下;一下子事后二面面试官过来了,是个成熟的大叔,

二面只问了两个东西,一个jvm,一个并发编程,jvm主要是性能调优,jstack的使用,full GC和minorGC的分析等,并发编程问的很细,

发问多个线程达到同一个状态而后再一块儿执行,达到某一个状态以后再继续并发执行,这种怎么实现,答:jdk5以后有一个CyclicBarrir,

经过这个来实现,它能够重用等balabala说了一些,再发问读写锁中加读锁后如何避免写线程饿死,答:加策略balabala,发问如何实

现控制线程www.qiangeseo.com在某段时间内完成,不完成就撤销,答:实现Callable接口,返回FutureTask类或者Future接口,而后去触发撤销操做。

开始问项目,描述一下对帐系统,balabala…数据量大吗,并发量高吗,数据库怎么设计的等,随后让我等一会,又过来一个面试官,

问我业务,你在第三方支付公司,能不能讲一下支付的技术流程,balabala…把本身理解的支付流程讲了一下,最后补了一句,

支付的细节业务很复杂,我也没彻底明白呢,汗,让我等了一会,随后面试官说你回去等消息吧,我想完蛋了吧,难道由于业务不熟被刷,

真不甘心;心凉了一个星期,结果hr在星期一打电话说让星期四去最后一面,是技术总监的面试,星期四屁颠屁颠的去了

(话说百度大厦离国贸太远了,地铁每次要坐一个半小时,我也是跪了),四面开始,发问异步处理的幂等性,不是很难,

惟一性索引或者开发分布式锁呗,随后风格立马就转了,不问技术了,发问你以为你来百度能给百度带来什么样的价值,

你但愿你加入的百度的团队是一个什么样的团队,你如何和产品经理沟通,假如你和其余研发接口制定没法统一你该如何解决等,

一点准备都没有,回答的结结巴巴非常很差,哎,听天由命吧!

阿里

第五个面的是阿里,百度面完等消息,闲来无事查看公司招聘信息,看到阿里招聘薪资很诱人。

哈哈,我就是这样一个无节操的人,开始是电话面试,而后是面试,二面和三面,主要面试技术点有如下 :

JVM相关:

1.    jvm中一次完整的GC流程(从ygc到fgc)是怎样的,重点讲讲对象如何晋升到老年代,几种主要的jvm参数等

2.    你知道哪几种垃圾收集器,各自的优缺点,重点讲下cms

3.    当出现了内存溢出,你怎么排错

4.    JVM内存模型的相关知识了解多少

5.    简单说说你了解的类加载器

6.    JAVA的反射机制

网络:

1.    http1.0和http1.1有什么区别

2.    TCP三次握手和四次挥手的流程,为何断开链接要4次,若是握手只有两次,会出现什么

3.    TIME_WAIT和CLOSE_WAIT的区别

4.    说说你知道的几种HTTP响应码

5.    架构设计与分布式

6.    tomcat如何调优,各类参数的意义

7.    常见的缓存策略有哪些,大家项目中用到了什么缓存系统,如何设计的,Redis的使用要注意什么,持久化方式,内存设置,集群,淘汰策略等

8.    如何防止缓存雪崩

9.    分布式集群下如何作到惟一序列号

10.  设计一个秒杀系统,30分钟没付款就自动关闭交易

11.  如何作一个分布式锁

12.  用过哪些MQ,怎么用的,和其余mq比较有什么优缺点,MQ的链接是线程安全的吗

13.  MQ系统的数据如何保证不丢失

14.  分布式事务的原理,如何使用分布式事务

15.  什么是一致性hash

16.  说说你知道的几种HASH算法,简单的也能够

17.  什么是paxos算法

18.  redis和memcached 的内存管理的区别等等

后面给了我offer。可是最近996不知道如何选择。

总结

就写到这了,写的有点多了,也算是给这两个星期面试作一个总结,查漏补缺,祝本身好运吧,也但愿正在求职或者打算跳槽的 程序员看到这个文章能有一点点帮助或收获,我就心满意足了。

佩佩寄语:大厂工资高,入职要求天然高,通常来讲大厂面试都比较重视基础,特别是偏向于一些原理方面的知识。这就须要咱们在平常学习中不光要知其然,还须要知其因此然,这样才能在技术不断更替下让本身立于不败之地

相关文章
相关标签/搜索