文档章节

阿里、网易等大公司面试题总结

满风
 满风
发布于 2017/03/17 16:43
字数 2162
阅读 194
收藏 5

本人亲身经历 网易、阿里第三轮 、等大公司的问题如下:

问过支付系统架构设计 ?
秒杀设计 ? 
还有java 内存模型?
负载 各层级模型 区别  为 什么要7 层负载 ?
cpu使用率低,load高 什么原因怎么排查?
虚拟机底层?
还有域名解析原理和过程?
http tcp 协议
redis 集合存储实现原理?
锁的实现原理?
spring、dubbo框架源码 等等
还有问题netty相关等
netty api   有哪些 我说我不知道 当我知道zk的api  于是 我就说了
你没 他 阿里二轮问了dubbo  三轮是问dubbo 重新设计我要怎么做!
最后还问我 计算机原理 整体让我讲一遍  懵逼

阻塞队列实现原理?

mysql事务隔离级别的实现原理?

mysql索引实现原理?数据库如何存储和检索的?

 

另外,附网友总结一篇:

一、心态

心态很重要!心态很重要!心态很重要!重要的事情说三遍,这一点我觉得是必须放到前面来讲。

找工作之前,有一点你必须清楚,就是找工作是一件看缘分的事情,不是你很牛逼,你就一定能进你想进的公司,都是有一个概率在那。如果你基础好,项目经验足,同时准备充分,那么你拿到offer的概率就会比较高;相反,如果你准备不充分,基础也不好,那么你拿到offer的概率就会比较低,但是你可以多投几家公司,这样拿到offer的几率就要大一点,因为你总有运气好的时候。所以,不要惧怕面试,刚开始失败了没什么的,多投多尝试,面多了你就自然能成面霸了。得失心也不要太重,最后每个人都会有offer的。

二、基础

基础这东西,各个公司都很看重,尤其是BAT这种大公司,他们看中人的潜力,他们舍得花精力去培养,所以基础是重中之重。之前很多人问我,项目经历少怎么办,那就去打牢基础,当你的基础好的发指的时候,你的其他东西都不重要了。

基础无外乎几部分:语言(C/C++或java),操作系统,TCP/IP,数据结构与算法,再加上你所熟悉的领域。这里面其实有很多东西,各大面试宝典都有列举。

 

J2SE基础

 

1. 九种基本数据类型的大小,以及他们的封装类。

 

2. Switch能否用string做参数?

 

3. equals与==的区别。

 

4. Object有哪些公用方法?

 

5. Java的四种引用,强弱软虚,用到的场景。

 

6. Hashcode的作用。

 

7. ArrayList、LinkedList、Vector的区别。

 

8. String、StringBuffer与StringBuilder的区别。

 

9. Map、Set、List、Queue、Stack的特点与用法。

 

10. HashMap和HashTable的区别。

 

11. HashMap和ConcurrentHashMap的区别,HashMap的底层源码。

 

12. TreeMap、HashMap、LindedHashMap的区别。

 

13. Collection包结构,与Collections的区别。

 

14. try catch finally,try里有return,finally还执行么?

 

15. Excption与Error包结构。OOM你遇到过哪些情况,SOF你遇到过哪些情况。

 

16. Java面向对象的三个特征与含义。

 

17. Override和Overload的含义去区别。

 

18. Interface与abstract类的区别。

 

19. Static class 与non static class的区别。

 

20. java多态的实现原理。

 

21. 实现多线程的两种方法:Thread与Runable。

 

22. 线程同步的方法:sychronized、lock、reentrantLock等。

 

23. 锁的等级:方法锁、对象锁、类锁。

 

24. 写出生产者消费者模式。

 

25. ThreadLocal的设计理念与作用。

 

26. ThreadPool用法与优势。

 

27. Concurrent包里的其他东西:ArrayBlockingQueue、CountDownLatch等等。

 

28. wait()和sleep()的区别。

 

29. foreach与正常for循环效率对比。

 

30. Java IO与NIO。

 

31. 反射的作用于原理。

 

32. 泛型常用特点,List<String>能否转为List<Object>。

 

33. 解析XML的几种方式的原理与特点:DOM、SAX、PULL。

 

34. Java与C++对比。

 

35. Java1.7与1.8新特性。

 

36. 设计模式:单例、工厂、适配器、责任链、观察者等等。

 

37. JNI的使用。

 

Java里有很多很杂的东西,有时候需要你阅读源码,大多数可能书里面讲的不是太清楚,需要你在网上寻找答案。

 

推荐书籍:《java核心技术卷I》《Thinking in java》《java并发编程》《effictive java》《大话设计模式》

 

JVM

 

1. 内存模型以及分区,需要详细到每个区放什么。

 

2. 堆里面的分区:Eden,survival from to,老年代,各自的特点。

 

3. 对象创建方法,对象的内存分配,对象的访问定位。

 

4. GC的两种判定方法:引用计数与引用链。

 

5. GC的三种收集方法:标记清除、标记整理、复制算法的原理与特点,分别用在什么地方,如果让你优化收集方法,有什么思路?

 

6. GC收集器有哪些?CMS收集器与G1收集器的特点。

 

7. Minor GC与Full GC分别在什么时候发生?

 

8. 几种常用的内存调试工具:jmap、jstack、jconsole。

 

9. 类加载的五个过程:加载、验证、准备、解析、初始化。

 

10. 双亲委派模型:Bootstrap ClassLoader、Extension ClassLoader、ApplicationClassLoader。

 

11. 分派:静态分派与动态分派。

 

JVM过去过来就问了这么些问题,没怎么变,内存模型和GC算法这块问得比较多,可以在网上多找几篇博客来看看。

 

推荐书籍:《深入理解java虚拟机》

 

操作系统

 

1. 进程和线程的区别。

 

2. 死锁的必要条件,怎么处理死锁。

 

3. Window内存管理方式:段存储,页存储,段页存储。

 

4. 进程的几种状态。

 

5. IPC几种通信方式。

 

6. 什么是虚拟内存。

 

7. 虚拟地址、逻辑地址、线性地址、物理地址的区别。

 

因为是做android的这一块问得比较少一点,还有可能上我简历上没有写操作系统的原因。

 

推荐书籍:《深入理解现代操作系统》

 

TCP/IP

 

1. OSI与TCP/IP各层的结构与功能,都有哪些协议。

 

2. TCP与UDP的区别。

 

3. TCP报文结构。

 

4. TCP的三次握手与四次挥手过程,各个状态名称与含义,TIMEWAIT的作用。

 

5. TCP拥塞控制。

 

6. TCP滑动窗口与回退N针协议。

 

7. Http的报文结构。

 

8. Http的状态码含义。

 

9. Http request的几种类型。

 

10. Http1.1和Http1.0的区别

 

11. Http怎么处理长连接。

 

12. Cookie与Session的作用于原理。

 

13. 电脑上访问一个网页,整个过程是怎么样的:DNS、HTTP、TCP、OSPF、IP、ARP。

 

14. Ping的整个过程。ICMP报文是什么。

 

15. C/S模式下使用socket通信,几个关键函数。

 

16. IP地址分类。

 

17. 路由器与交换机区别。

 

网络其实大体分为两块,一个TCP协议,一个HTTP协议,只要把这两块以及相关协议搞清楚,一般问题不大。

 

推荐书籍:《TCP/IP协议族》

 

数据结构与算法

 

1. 链表与数组。

 

2. 队列和栈,出栈与入栈。

 

3. 链表的删除、插入、反向。

 

4. 字符串操作。

 

5. Hash表的hash函数,冲突解决方法有哪些。

 

6. 各种排序:冒泡、选择、插入、希尔、归并、快排、堆排、桶排、基数的原理、平均时间复杂度、最坏时间复杂度、空间复杂度、是否稳定。

 

7. 快排的partition函数与归并的Merge函数。

 

8. 对冒泡与快排的改进。

 

9. 二分查找,与变种二分查找。

 

10. 二叉树、B+树、AVL树、红黑树、哈夫曼树。

 

11. 二叉树的前中后续遍历:递归与非递归写法,层序遍历算法。

 

12. 图的BFS与DFS算法,最小生成树prim算法与最短路径Dijkstra算法。

 

13. KMP算法。

 

14. 排列组合问题。

 

15. 动态规划、贪心算法、分治算法。(一般不会问到)

 

16. 大数据处理:类似10亿条数据找出最大的1000个数………等等

 

算法的话其实是个重点,因为最后都是要你写代码,所以算法还是需要花不少时间准备,这里有太多算法题,写不全,我的建议是没事多在OJ上刷刷题(牛客网、leetcode等),剑指offer上的算法要能理解并自己写出来,编程之美也推荐看一看。

 

推荐书籍:《大话数据结构》《剑指offer》《编程之美》

© 著作权归作者所有

满风

满风

粉丝 94
博文 171
码字总数 174498
作品 0
杭州
技术主管
私信 提问
前端笔试、面试

让 BAT 的 Offer 不再难拿 随着各大公司春招的开始,很多小伙伴都行动起来了,我有幸能够加入百度并和大家分享自己的经验心得。由于我面试的都是比较大的公司,所以自然也是做了这方面的准备...

掘金官方
2018/01/11
0
0
掘金秋招征文大赛评选结果

为期一月的掘金秋招技术征文活动结束了,获奖作者如下 一等奖3名 第一名 Kindle Paperwhite 面试过阿里等互联网大公司,我知道了这些套路 | 掘金技术征文 第二名 cherry樱桃G80-3800青轴 腾讯...

Plum
2017/10/11
0
0
Android-Java面试

2016 年末,腾讯,百度,华为,搜狗和滴滴面试题汇总 2016 年未,腾讯,百度,华为,搜狗和滴滴面试题汇总 各大公司 Java 后端开发面试题总结 各大公司 Java 后端开发面试题总结 刚出炉的一线...

掘金官方
2018/01/02
0
0
java面试题栈

JavaEE面试题收集 Java EE平台构建于Java SE平台之上,Java EE平台提供一组API和运行环境来开发和运行大规模的,多层的,可扩展的,可靠的和安全的网络应用程序。这里会不断收集和更新JavaE...

掘金官方
2017/12/06
0
0
网易java实习生面试10个问题,你会几个?

此前,w3cschool app分享了阿里巴巴java面经、小米java面经、网易java面经。 近日,我们在w3cschool app开发者头条上,可以看到网易java实习生面经。 在分享网易java实习生面经之前,我们还是...

W3Cschool
2017/12/05
0
0

没有更多内容

加载失败,请刷新页面

加载更多

zk服务预启动和启动选举过程

QuorumPeerMain类public static void main(String[] args) { QuorumPeerMain main = new QuorumPeerMain(); try { main.initializeAndRun(args); } catch (Illega......

writeademo
27分钟前
5
0
深究递归和迭代的区别、联系、优缺点及实例对比

http://blog.csdn.net/laoyang360/article/details/7855860 http://www.zhihu.com/question/20278387 深究递归和迭代的区别、联系、优缺点及实例对比 1.概念区分 递归的基本概念:程序调用自身...

slagga
30分钟前
4
0
基于SOM-TL6678核心板而研发的TL6678-EasyEVM开发板硬件说明书

TL6678-EasyEVM是广州创龙基于SOM-TL6678核心板而研发的一款多核高性能DSP开发板。开发板采用核心板+底板方式,底板采用沉金无铅工艺的四层板设计,尺寸为200mm*106.65mm,它为用户提供了SOM...

Tronlong创龙
33分钟前
3
0
分别在有网和无网状态下批量安装python库

## 连网状态下,批量安装python库查看当前python环境下已安装的库包版本查看命令:pip freeze"""alabaster==0.7.10anaconda-client==1.6.3anaconda-navigator==1.6.2anaconda-projec......

KYO4321
36分钟前
3
0
fiddler、Charles-断点

一、添加Charles断点 1、用Charles抓包发起一次接口请求 2、对要打断点的接口右键,选择【Breakpoints】 二、Charles断点设置 1、点击Charles菜单-【Proxy】-【Breakpoint...】,此时会弹出【...

果树啊
36分钟前
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部