JAVA高级-面试题总结

最近面试了一些公司,针对面试中遇到的问题在此记录,提升自己,造福大家

一、java源码相关

  1.  ArrayList创建和add等各种api使用原理  

  2. HashMap 的创建,put原理,和HashTable的区别,resize的原理

  3. HashMap和HashTable在1.7版本之后的区别,针对创建时和put时处理的方式不同(红黑树,CAS、ABA处理)

  4. 各种IO交互(AIO/ NIO/ BIO)

二、 JVM相关

  (bookname:深入理解java虚拟机)

  1. jvm分区

  2. java文件加载到gc全流程

  3. gc收集算法(标记计数算法,可达性算法)gc清理逻辑

  4. G1/CMS收集器

  5. 堆栈溢出原因,处理

  6. 内存分配和回收策略

  7. 虚拟机贱虫和故障处理工具

  8. jvm调优

  9. web容器加载器架构实现(tomcat,jetty……)

  10. 线程安全,锁优化

三、多线程

  1. 线程池的创建有几种方式

  2. submit和excute使用的区别,怎样避免死锁

  3. 线程的锁机制(lock和synchronized)

  4. 线程调度相关

四、数据库

  1. mysql中innodb myisam 两种引擎区别,是否支持事物,索引实现(B+,Hash)复合索引/二叉树

  2. group by和order by

  3. 数据库调优

  4. 大量数据下分库分表处理

  5. 跨多数据库查询

  6. cap,CAP即,一致性(Consistency), 可用性(Availability), 分区容忍性(Partition tolerance);

  7. redis有什么优点(单线程,分布式,持久化,事务,原子性)

  8. redis的主从 、哨兵的实现原理

  9. redis支持的数据操作类型,发布订阅,计数器

  10. redis作为注册中心的优点,和zk的区别

五、Spring框架相关

  1. ioc实现原理

  2. aop具体实现,动态代理

  3. 工厂bean和bean工厂

  4. 反射使用

  5. 注解实现

六、分布式

  1. dubbo具体调用原理(消费者&服务者)

  2. 多注册中心的使用场景

  3. 负载均衡策略

  4. 注册中心的注册原理(zk和redis注册中心有什么区别)

目前遇到的问题是这些,欢迎各位看官留言补充。BX

    原文作者:java线程池
    原文地址: http://www.cnblogs.com/ning-blogs/p/10099640.html
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞