一、阿里技术一面

  1. Java IO流的层次结构?
  2. 请说出罕用的异样类型?
  3. SKU的全称是什么,SKU与SPU的区别及关系?
  4. FileInputStream在应用完当前,不敞开流,想二次应用能够怎么操作?
  5. 设计一个分步式登录零碎?
  6. Spring加载过程?
  7. 本人有没有写过相似Spring这样的AOP事务?
  8. Java中 try..catch敞开流的语法糖?
  9. 如何设计一个秒杀零碎?要思考什么?
  10. 有没有遇到进线上GC,呈现的症状是什么样的,怎么解决的?
  11. spring的加载过程?
  12. atomic与 volatile的区别?
  13. Thread的 notify给notifyAll的区别?
  14. notifiy是唤醒的那一个线程?
  15. Thread.sleep唤醒当前是否须要从新竞争?
  16. 单例有多少种写法?有什么区别?你罕用哪一种单例,为什么用这种?
  17. 问一个Thread.join相干的问题?
  18. 商品相干模块零碎怎么设计数据模型?
  19. 写一个JAVA死锁的列子?
  20. 如何解决死锁?
  21. GC回收算法,及实现原理?
  22. HashMap数据存储构造? key反复了怎么办?是如何解决的?
  23. Spring AOP的实现原理,底层用什么实现的?

二、阿里技术二面

电话面试次要考查3块内容:

  1. Java的相干基础知识,开源框架的原理,JVM,多线程,高并发,中间件等;
  2. 之前我的项目经验,使用的技术,遇到的问题,如何解决,集体有什么播种和成长;
  3. 对于技术的激情(平时是否看些技术书籍,逛论坛,写博客,写源代码或程序等);

三、JAVA开发技术面试可能问到的问题

  1. 咱们次要考核的是网络nio分布式数据库高并发大数据
  2. 自定义表格的实现?
  3. 动静表单设计?
  4. in-jvm(必考)以及jmm缓存模型如何调优?
  5. 罕用的RPC框架
  6. nio和io
  7. 并发编程,设计模式
  8. 地图组件?
  9. hashmap有什么破绽会导致他变慢?
  10. 如何给hashmap的key对象设计他的hashcode?
  11. 泛型通配符?在什么状况下应用?
  12. 后端方面:redis?分布式框架dubbo(阿里巴巴开源框架)?设计模式?
  13. 场景式的问题:秒杀,能列出常见的排队、验证码、库存扣减形式对系统高并发的影响?
  14. 能依据理论的须要构建缓存构造进步进步网站的访问速度,纯熟应用ehcache、oscache,理解memcache。
  15. 理解基于dns轮询的负载平衡,纯熟配置web服务器实现负载平衡,程序级能综合应用基于hash或取模等伎俩实现软负载。
  16. 相熟分布式数据库设计和优化技术,纯熟应用mysql、oracle、SqlServer等支流数据库,相熟hadoop hbase mangodb redis ehcache、oscache memcache。对于大数据量的数据库解决采纳分表分库、数据库读写拆散、建设缓存等伎俩优化性能。
  17. 熟练掌握lucene,能基于lucene开发大型的搜索引擎,并能用lucene来改善和优化数据库的like查问。

四、JAVA方向技术考察点(补充):

  1. 把握Java编程语言,蕴含io/nio/socket/multi threads/collection/concurrency等性能的应用;
  2. 熟练掌握jvm(sun hotspot和ibm j9)内存模型、gc垃圾回收调优等技能;
  3. 精通JVM,JMM,MVC架构,纯熟应用struts2。
  4. 纯熟应用spring、struts、ibatis构建利用零碎。
  5. 纯熟应用Servlet,jsp,freemark等前端技术。
  6. 纯熟应用axis搭建基于SOAP协定的WebService服务接口。
  7. 纯熟应用MAVEN构建我的项目工程。
  8. 纯熟应用tomcat等web服务。
  9. 纯熟应用mysql等关系型数据库,相熟mysql集群搭建。
  10. 纯熟应用redis等NOSQL技术。
  11. 相熟tcp、http协定。
  12. 相熟nginx、haproxy等配置。
  13. 相熟javascript、ajax等技术。
  14. 相熟支流分布式文件系统FastDFS等。
  15. 相熟JMS,可纯熟应用ActiveMQ。
  16. 底层计算机了解内存治理/数据挖掘零碎
  17. 可靠性和可用性如何了解~
  18. jsp和sever lap比照
  19. 数据库到界面,字符集转化
  20. 基栈
  21. jvm优化cup高的时候如果剖析和监控
  22. java curb突出细节问题
  23. 分布式缓存文档如何分流
  24. 迁徙数据库垂直宰割
  25. 高并发如何解决前端高并发应用层
  26. LB设计load balance
  27. 负载平衡
  28. 防网络攻击
  29. 数据日志事件监控后告诉
  30. 数据库事务实现的底层机制
  31. 字符串空格输出的网络攻击
  32. Quartz框架的底层原理
  33. 数据库同步中不通过数据库引擎间接读日志等形式同步数据

五、我的项目局部

  1. 缓存的应用,如果当初须要实现一个简略的缓存,供搜寻框中的ajax异步申请调用,应用什么构造?
  2. 内存中的缓存不能始终存在,用什么算法定期将搜寻权重较低的entry去掉?
  3. TCP如何保障安全性
  4. 红黑树的问题,B+数
  5. JDK1.8中对HashMap的加强,如果一个桶上的节点数量过多,链表+数组的构造就会转换为红黑树。
  6. 我的项目中应用的单机服务器,如果将它部署成分布式服务器?
  7. MySQL的常见优化形式、定为慢查问
  8. 手写一个线程平安的单例模式

六、进阿里必会常识:

  1. 算法和数据结构数组、链表、二叉树、队列、栈的各种操作(性能,场景)
  2. 二分查找和各种变种的二分查找
  3. 各类排序算法以及复杂度剖析(快排、归并、堆)
  4. 各类算法题(手写)
  5. 了解并能够剖析工夫和空间复杂度。
  6. 动静布局(口试回回有。。)、贪婪。
  7. 红黑树、AVL树、Hash树、Tire树、B树、B+树。
  8. 图算法(比拟少,也就两个最短门路算法了解吧)
  9. 计算机网络OSI7层模型(TCP4层)每层的协定
  10. url到页面的过程
  11. HTTPhttp/https 1.0、1.1、2.0
  12. get/post以及幂等性
  13. http协定头相干
  14. 网络攻击(CSRF、XSS)
  15. TCP/IP三次握手、四次挥手
  16. 拥塞管制(过程、阈值)
  17. 流量管制与滑动窗口
  18. TCP与UDP比拟
  19. 子网划分(个别只有口试有)
  20. DDos攻打
  21. (B)IO/NIO/AIO三者原理,各个语言是怎么实现的
  22. Netty
  23. Linux内核select poll epoll
  24. 数据库(最多的还是mysql,Nosql有redis)索引(包含分类及优化形式,生效条件,底层构造)
  25. sql语法(join,union,子查问,having,group by)
  26. 引擎比照(InnoDB,MyISAM)
  27. 数据库的锁(行锁,表锁,页级锁,意向锁,读锁,写锁,乐观锁,乐观锁,以及加锁的select sql形式)
  28. 隔离级别,顺次解决的问题(脏读、不可反复读、幻读)
  29. 事务的ACID
  30. B树、B+树
  31. 优化(explain,慢查问,show profile)
  32. 数据库的范式。
  33. 分库分表,主从复制,读写拆散。
  34. Nosql相干(redis和memcached区别之类的,如果你相熟redis,redis还有一堆要问的)
  35. 操作系统:过程通信IPC(几种形式),与线程区别
  36. OS的几种策略(页面置换,过程调度等,每个外面有几种算法)
  37. 互斥与死锁相干的
  38. linux常用命令(问的时候都会给具体某一个场景)
  39. Linux内核相干(select、poll、epoll)
  40. 编程语言(这里只说Java):把我之后的面通过一遍,Java感觉笼罩的就差不多了,不过上面还是分个类。
  41. Java根底(面向对象、四个个性、重载重写、static和final等等很多货色)
  42. 汇合(HashMap、ConcurrentHashMap、各种List,最好联合源码看)
  43. 并发和多线程(线程池、SYNC和Lock锁机制、线程通信、volatile、ThreadLocal、CyclicBarrier、Atom包、CountDownLatch、AQS、CAS原理等等)
  44. JVM(内存模型、GC垃圾回收,包含分代,GC算法,收集器、类加载和双亲委派、JVM调优,内存透露和内存溢出)
  45. IO/NIO相干
  46. 反射和代理、异样、Java8相干、序列化
  47. 设计模式(罕用的,jdk中有的)
  48. Web相干(servlet、cookie/session、Spring)

七、面试技巧

1、答非所问:

感觉到答案说进去对方会不待见的时候,能够这么做:有关联性的答非所问,留神强调本人的想法,争取让面试官可能共情,比方深圳的房价能够引人共情、电商相干的大平台、稳固、有回升空间等。

2、面试的状态很重要:

两个例子,上月一个胜利offer的候选人,非互联网背景,公司也不是一线的,然而面试时体现出对阿里很强烈的趣味,HR预先顺便向咱们提到,对这位候选人印象很粗浅;

另一位明天刚挂的候选人,两轮技术都是一举拿下,最初HR面挂了,HR给咱们的反馈是,候选人刚从本人的守业公司到职,貌似情绪很高涨,对本人也没什么想法。

综上所述,面试时既不要气宇轩昂,过于被动,也不要过于夸大,而是在于展示本人对一个不错机会的尊重和争取,让面试官感觉你对他们,对这个岗位有很大的趣味。

答案获取,请关注公众号【不止于编程】,回复:阿里巴巴面试

近300页文档,图文并茂,还请你点个赞????