面试题汇总

java 基础

 

八种基本数据类型的大小,以及他们的封装类引用数据类型Switch能否用string做参数equals与==的区别自动装箱,常量池Object有哪些公用方法Java的四种引用,强弱软虚,用到的场景Hashcode的作用HashMap的hashcode的作用为什么重载hashCode方法?ArrayList、LinkedList、Vector的区别String、StringBuffer与StringBuilder的区别Map、Set、List、Queue、Stack的特点与用法HashMap和HashTable的区别JDK7与JDK8中HashMap的实现HashMap和ConcurrentHashMap的区别,HashMap的底层源码ConcurrentHashMap能完全替代HashTable吗为什么HashMap是线程不安全的如何线程安全的使用HashMap多并发情况下HashMap是否还会产生死循环TreeMap、HashMap、LindedHashMap的区别Collection包结构,与Collections的区别try?catch?finally,try里有return,finally还执行么Excption与Error包结构,OOM你遇到过哪些情况,SOF你遇到过哪些情况Java(OOP)面向对象的三个特征与含义Override和Overload的含义去区别Interface与abstract类的区别Static?class?与non?static?class的区别java多态的实现原理foreach与正常for循环效率对比Java?IO与NIOjava反射的作用于原理泛型常用特点解析XML的几种方式的原理与特点:DOM、SAXJava1.7与1.8,1.9,10 新特性设计模式:单例、工厂、适配器、责任链、观察者等等JNI的使用AOP是什么OOP是什么AOP与OOP的区别

 

多线程

 

 

什么是线程?什么是线程安全和线程不安全?什么是自旋锁?什么是Java内存模型?什么是CAS?什么是乐观锁和悲观锁?什么是AQS?什么是原子操作?在Java Concurrency API中有哪些原子类(atomic classes)?什么是Executors框架?什么是阻塞队列?如何使用阻塞队列来实现生产者-消费者模型?什么是Callable和Future?什么是FutureTask?什么是同步容器和并发容器的实现?什么是多线程?优缺点?什么是多线程的上下文切换?ThreadLocal的设计理念与作用?ThreadPool(线程池)用法与优势?Concurrent包里的其他东西:ArrayBlockingQueue、CountDownLatch等等。synchronized和ReentrantLock的区别?Semaphore有什么作用?Java Concurrency API中的Lock接口(Lock interface)是什么?对比同步它有什么优势?Hashtable的size()方法中明明只有一条语句”return count”,为什么还要做同步?ConcurrentHashMap的并发度是什么?ReentrantReadWriteLock读写锁的使用?CyclicBarrier和CountDownLatch的用法及区别?LockSupport工具?Condition接口及其实现原理?Fork/Join框架的理解?wait()和sleep()的区别?线程的五个状态(五种状态,创建、就绪、运行、阻塞和死亡)?start()方法和run()方法的区别?Runnable接口和Callable接口的区别?volatile关键字的作用?Java中如何获取到线程dump文件?线程和进程有什么区别?线程实现的方式有几种(四种)?高并发、任务执行时间短的业务怎样使用线程池?并发不高、任务执行时间长的业务怎样使用线程池?并发高、业务执行时间长的业务怎样使用线程池?如果你提交任务时,线程池队列已满,这时会发生什么?锁的等级:方法锁、对象锁、类锁?如果同步块内的线程抛出异常会发生什么?并发编程(concurrency)并行编程(parallellism)有什么区别?如何保证多线程下 i++ 结果正确?一个线程如果出现了运行时异常会怎么样?如何在两个线程之间共享数据?生产者消费者模型的作用是什么?怎么唤醒一个阻塞的线程?Java中用到的线程调度算法是什么单例模式的线程安全性?线程类的构造方法、静态块是被哪个线程调用的?同步方法和同步块,哪个是更好的选择?如何检测死锁?怎么预防死锁?

 

设计模式

 

 

装饰器模式工厂模式单例模式观察者模式动态代理模式适配器模式模板模式策略模式JVM

 

内存模型以及分区,需要详细到每个区放什么。对象创建方法,对象的内存分配,对象的访问定位。GC的两种判定方法:引用计数与引用链。GC的三种收集方法:标记清除、标记整理、复制算法的原理与特点,分别用在什么地方,如果让你优化收集方法,有什么思路?GC收集器有哪些?CMS收集器与G1收集器的特点。Minor?GC与Full?GC分别在什么时候发生?几种常用的内存调试工具:jmap、jstack、jconsole。类加载的五个过程:加载、验证、准备、解析、初始化。双亲委派模型:Bootstrap?ClassLoader、Extension?ClassLoader、ApplicationClassLoader。分派:静态分派与动态分派。JVM过去过来就问了这么些问题,没怎么变,内存模型和GC算法这块问得比较多,可以在网上多找几篇博客来看看。推荐书籍:《深入理解java虚拟机》

 

数据结构与算法

 

 

链表与数组。队列和栈,出栈与入栈。链表的删除、插入、反向。字符串操作。Hash表的hash函数,冲突解决方法有哪些。各种排序:冒泡、选择、插入、希尔、归并、快排、堆排、桶排、基数的原理、平均时间复杂度、最坏时间复杂度、空间复杂度、是否稳定。快排的partition函数与归并的Merge函数。对冒泡与快排的改进。二分查找,与变种二分查找。二叉树、B+树、AVL树、红黑树、哈夫曼树。二叉树的前中后续遍历:递归与非递归写法,层序遍历算法。图的BFS与DFS算法,最小生成树prim算法与最短路径Dijkstra算法。KMP算法。排列组合问题。动态规划、贪心算法、分治算法。(一般不会问到)大数据处理:类似10亿条数据找出最大的1000个数.........等等算法的话其实是个重点,因为最后都是要你写代码,所以算法还是需要花不少时间准备,这里有太多算法题,写不全,我的建议是没事多在OJ上刷刷题(牛客网、leetcode等),剑指offer上的算法要能理解并自己写出来,编程之美也推荐看一看

 

数据库

 

 

事务四大特性(ACID)原子性、一致性、隔离性、持久性数据库隔离级别,每个级别会引发什么问题,mysql默认是哪个级别innodb和myisam存储引擎的区别MYSQL的两种存储引擎区别(事务、锁级别等等),各自的适用场景查询语句不同元素(where、jion、limit、group by、having等等)执行先后顺序数据库的优化(从sql语句优化和索引两个部分回答)索引有B+索引和hash索引,各自的区别B+索引数据结构,和B树的区别索引的分类(主键索引、唯一索引),最左前缀原则,哪些情况索引会失效聚集索引和非聚集索引区别。有哪些锁(乐观锁悲观锁),select时怎么加排它锁关系型数据库和非关系型数据库区别数据库三范式,根据某个场景设计数据表(可以通过手绘ER图)数据库的读写分离、主从复制使用explain优化sql和索引long_query怎么解决内连接、外连接、交叉连接、笛卡儿积等死锁判定原理和具体场景,死锁怎么解决varchar和char的使用场景。mysql并发情况下怎么解决(通过事务、隔离级别、锁)数据库崩溃时事务的恢复机制(REDO日志和UNDO日志)查询语句不同元素(where、jion、limit、group by、having等等)执行先后顺序

 

Spring

 

 

IOC和DI是什么?Spring IOC 的理解,其初始化过程?BeanFactory 和 FactoryBean的区别?BeanFactory和ApplicationContext的区别?ApplicationContext 上下文的生命周期?Spring Bean 的生命周期?Spring AOP的实现原理?Spring 是如何管理事务的,事务管理机制?Spring 的不同事务传播行为有哪些,干什么用的?Spring 中用到了那些设计模式?Spring MVC 的工作原理?Spring如何解决循环依赖?Spring 如何保证 Controller 并发的安全?

 

Netty

 

 

BIO、NIO和AIONetty 的各大组件Netty的线程模型TCP 粘包/拆包的原因及解决方法了解哪几种序列化协议?包括使用场景和如何去选择Netty的零拷贝实现Netty的高性能表现在哪些方面

 

缓存

 

 

Redis用过哪些数据数据,以及Redis底层怎么实现Redis缓存穿透,缓存雪崩如何使用Redis来实现分布式锁Redis的并发竞争问题如何解决Redis持久化的几种方式,优缺点是什么,怎么实现的Redis的缓存失效策略Redis集群,高可用,原理Redis缓存分片Redis的数据淘汰策略

 

技术框架

 

 

看过哪些开源框架的源码为什么要用Redis,Redis有哪些优缺点?Redis如何实现扩容?Netty是如何使用线程池的,为什么这么使用为什么要使用Spring,Spring的优缺点有哪些Spring的IOC容器初始化流程Spring的IOC容器实现原理,为什么可以通过byName和ByType找到BeanSpring AOP实现原理消息中间件是如何实现的,技术难点有哪些

 

技术深度

 

 

事务的实现原理有没有看过JDK源码,看过的类实现原理是什么。HTTP协议TCP协议一致性Hash算法JVM如何加载字节码文件类加载器如何卸载字节码IO和NIO的区别,NIO优点Java线程池的实现原理,keepAliveTime等参数的作用。HTTP连接池实现原理数据库连接池实现原理数据库的实现原理

 

分布式

 

 

什么是CAP定理CAP 理论和 BASE 理论CAP 理论CAP 理论和最终一致性最终一致性实现方式CAP 理论和 BASE 理论一致性 Hash分布式事务,两阶段提交。如何实现分布式锁如何实现分布式Session如何保证消息的一致性负载均衡正向代理(客户端代理)和反向代理(服务器端代理)CDN实现原理怎么提升系统的QPS和吞吐量Dubbo的底层实现原理和机制描述一个服务从发布到被消费的详细过程分布式系统怎么做服务治理接口的幂等性的概念消息中间件如何解决消息丢失问题Dubbo的服务请求失败怎么处理重连机制会不会造成错误对分布式事务的理解如何实现负载均衡,有哪些算法可以实现?Zookeeper的用途,选举的原理是什么?数据的垂直拆分水平拆分。zookeeper原理和适用场景zookeeper watch机制redis/zk节点宕机如何处理分布式集群下如何做到唯一序列号用过哪些MQ,怎么用的,和其他mq比较有什么优缺点,MQ的连接是线程安全的吗MQ系统的数据如何保证不丢失列举出你能想到的数据库分库分表策略;分库分表后,如何解决全表查询的问

 

系统架构

 

 

如何搭建一个高可用系统哪些设计模式可以增加系统的可扩展性介绍设计模式,如模板模式,命令模式,策略模式,适配器模式、桥接模式、装饰模式,观察者模式,状态模式,访问者模式。抽象能力,怎么提高研发效率。什么是高内聚低耦合,请举例子如何实现什么情况用接口,什么情况用消息如果AB两个系统互相依赖,如何解除依赖如何写一篇设计文档,目录是什么什么场景应该拆分系统,什么场景应该合并系统系统和模块的区别,分别在什么场景下使用实战能力有没有处理过线上问题?出现内存泄露,CPU利用率标高,应用无响应时如何处理的。开发中有没有遇到什么技术问题?如何解决的如果有几十亿的白名单,每天白天需要高并发查询,晚上需要更新一次,如何设计这个功能。新浪微博是如何实现把微博推给订阅者Google是如何在一秒内把搜索结果返回给用户的。12306网站的订票系统如何实现,如何保证不会票不被超卖。如何实现一个秒杀系统,保证只有几位用户能买到某件商品。

 

LINUX

 

 

硬链接和软连接区别kill用法,某个进程杀不掉的原因(进入内核态,忽略kill信号)linux用过的命令系统管理命令(如查看内存使用、网络情况)管道的使用 |grep的使用,一定要掌握,每次都会问在文件中查找shell脚本find命令awk使用

 

TCP/IP

 

 

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

TCP报文结构。

TCP的三次握手与四次挥手过程,各个状态名称与含义,TIMEWAIT的作用。TCP拥塞控制。TCP滑动窗口与回退N针协议。

Http的报文结构。Http的状态码含义。Http?request的几种类型。Http1.1和Http1.0的区别Http怎么处理长连接。

Cookie与Session的作用于原理。电脑上访问一个网页,整个过程是怎么样的:DNS、HTTP、TCP、OSPF、IP、ARP。

Ping的整个过程。ICMP报文是什么。C/S模式下使用socket通信,几个关键函数。IP地址分类。路由器与交换机区别。网络其实大体分为两块,一个TCP协议,一个HTTP协议,只要把这两块以及相关协议搞清楚,一般问题不大。推荐书籍:《TCP/IP协议族》

 

软能力

 

 

如何学习一项新技术,比如如何学习Java的,重点学习什么有关注哪些新的技术工作任务非常多非常杂时如何处理项目出现延迟如何处理和同事的设计思路不一样怎么处理如何保证开发质量职业规划是什么?

短期,长期目标是什么团队的规划是什么能介绍下从工作到现在自己的成长在那里说说你认为的服务端开发工程师应该具备哪些能力网络必备,高并发,JVM必会,各种分布式技术,看源码的能力。

说说你认为的架构师是什么样的,架构师主要做什么。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值