当前位置:文档之家› java开发工作经验面试题集锦(最新整理)

java开发工作经验面试题集锦(最新整理)

java开发工作经验面试题集锦(最新整理)
java开发工作经验面试题集锦(最新整理)

关于java基础

1.String,StringBuilder,StringBuffer区别是什么?底层数据结构是什么?分别是如何实现的?

2.HashSet的底层实现是什么?它与HashMap有什么关系?

3.Java 的并发包里面有那些知识点?

4.HashCode与HashMap的关系?

5.哈希函数的理解?

6.map在put()的做了哪些事?

7.如果发生hash碰撞,有什么方法可以解决?

8.各种类型的锁?

9.synchronize和lock?

10.hashTable的数据结构?

11.线程安全的map即HashTable和CurrentHashMap,底层的线程安全是如何实现的?

12.hashCode的原理?

13.什么情况下需要重写类的hashCode()方法?什么时候需要重写equals()方法?

14.hashmap添加元素,如果通过hash值得到的位置如果有元素,哪一种情况会取代所在的元素?

15.HashMap添加元素,如果是所得的桶数组的位置有值。该值则被添加到链表尾端,为什么会是

尾端?

16.ArrayList和hashmap底层结构,以及CurrentHashMap解决了什么问题;

17.Hashmap的是否线程安全?为什么是安全或者不安全?

18.HashMap、HashTable以及ConcurrentHashMap的区别;

19.volatile关键字的理解;用在哪些场景?

20.线程的理解以及其实现方式;

21.线程池的参数有哪些?实现原理;

22.线程同步方法有哪些?

23.缓存的原理?为什么要用缓存?为什么会比数据库查询快?

24.反射机制的理解;

25.Object中的方法;

26.String的toString()方法的实现?底层原理?

27.NIO与IO的异同;

28.垃圾回收机制的理解;

29.java8的新特性有哪些?如何使用?

30.static关键字的场景和意义;(拓展:final)

31.如何理解事务?

32.虚拟机的内存结构;

33.动态代理的两种实现方式;

34.悲观锁和乐观锁的区别

35.如何解决跨域问题?

36.xml文件解析方式有几种

37.synchronize的锁的类型

38.秒杀系统的设计

39.分库分表

40.Spring底层是如何实现的;

41.Tomcat容器启动的时候,spring的启动流程;

42.SpringAop除了动态代理,还用了其余的什么原理?

43.rpc框架

44.事务的隔离级别和传播机制

45.docker

46.高峰期如何进行分流

高并发

1.造成线程安全的主要因素有哪些:

2.互斥锁是什么?java锁如何分类?

3.关于锁名词的分类

4.线程的创建方式;

5.三种创建方式分别有什么区别?(最终可以追究到最底层)

6.线程池的核心参数是哪些?分别表示什么意义?

7.通过线程池创建线程的流程是什么?

8.Lock接口;

9.synchronize和volitile的区别?

10.设计一个高并发的网站通用的技术有哪些?

11.CAS是什么?

12.JUD是什么

分布式

1.关于分布式的一些基本概念

2.springboot与spring相比优势是什么?

3.springboot自动配置的原理是什么?

4.如果自己集成一个jar包到springboot中,该如何做?

5.如何解决分布式事务问题?

web

1.servlet的实现以及其中的方法;

2.token生成的原理;

常用的设计模式

关于前端

1.闭包的理解;

2.js函数的理解;

3.如何优化前端?

关于框架

spring

1.springIOC的理解;

2.spring是如何通过xml配置或者注解配置生成实例对象的?

3.springIOC的java底层原理;

4.反射

5.springAOP的理解;

6.springAOP的底层的实现原理;

7.spring如何解析视图;

8.spring的常用注解;

9.springmvc和Struts2的差异;

10.如何控制事务;

11.事物的隔离级别和传播机制;

12.Spring BeanFactory与FactoryBean的区别;

13.springAOP的应用场景;

mybatis

1.mybatis的结构?

2.配置文件如何配置?

3.mybatis处理多个参数的几种方式?

4.占位符有几种?区别是什么?

5.一级缓存和二级缓存的区别?

6.Mybatis的类型转换器?

7.mybatis接口没有实现类,他是如何操作数据库的?

hibernate

mybatis 与hibernate的对比;优势,劣势,原理,如何选择;

项目Mybatis Hibernate

开发效率较容易上手;需要手动管理sql较难上手;无需管理sql,专注业务

入门简单较难

灵活性sql更加灵活几乎不用写sql,封装性较大

性能相对较高相对较低

日志系统除了基本记录功能外,功能薄弱很多志系统非常健全,涉及广泛,包括:sql记录、关系

异常、优化警告、缓存提示、脏数据警告等

优化更容易更难

自动性半自动全自动

缓存有更好的二级缓存机制

移植性移植性低(绑定了sql)移植性高

适用场合 1.有复杂的查询业务;2.无hibernate实践经验的 1.无复杂的查询业务;2.能够熟练应用hibernate的

SpringBoot

1.springboot与springmvc最大的优势在哪?

2.一个加了事务注解的“新增方法”,抛出异常,数据有没有添加成功?

关于工具的使用

1.git和svn的区别以及各自优势

2.Jenkins的搭建和配置;

3.maven是如何管理jar包版本的;

关于数据库

关系型数据库

1.limit关键字从0到10与从100000到200000效率相差几个数量级,为什么?

2.mysql的架构;

3.索引的原理;

4.索引的选取原则(通用):

5.为什么索引导致查询效率高?操作数据效率低?

6.索引的底层结构是什么?是如何实现的?

7.哪些查询会用到索引?哪些查询用不到索引?

8.索引类型?

9.聚集索引和非聚集索引

10.聚集索引的优缺点

11.mysql索引的数据结构

12.数据库的隔离级别分别是什么?

13.sql的优化方案;

14.left join 与inner join的差别;

15.mysql的存储引擎MyIsam和InnoDB的区别;

16.主键和唯一索引有啥区别?

17.唯一索引能不能为空?

非关系型数据库

1.常用哪些非关系型数据库?哪些场景会用到?

2.redis如何进行持久化?

关于网络协议

1.UDP与TCP的异同;

2.http的理解;

3.webSocket编程;

4.什么是ajax?原生的ajax如何写?

5.比较get请求和post请求的异同;

关于linux操作

1.常用的文件操作命令;

2.查看线程信息的命令;

3.查看内存的命令;

4.部署项目的命令;

5.mac与Linux服务器文件传输命令;

关于算法

1.常用的排序算法有哪些,分别如何实现(原理)?

2.java中有哪些排序方式?原理是什么?

3.两个按降序排序的数组,用效率最高的算法组合成一个按降序排列的新数组;

4.回文字符串的个数;

5.一个若干字符串中括号的对数;

6.斐波那契的实现;

7.单向链表反转?

8.台阶问题?

9.输入一个字符串,输出一出现频率最高的字符,如果出现频率相同,则输出第一个字符;关于数据结构

1.常用的数据结构;

2.hashmap是什么数据结构?

3.堆、栈、队列的特性是什么?

4.树的应用场景是什么?

5.二叉树与红黑树的理解;

关于所做项目

1.读写如何设置同步和异步;

2.如何处理排他处理?

思路:数据库中存一个时间戳字段,每次加载页面的时候将时间戳带到页面隐藏域。向后台发送请求的时候将该时间戳与数据库中所存的时间戳对比,如果一致的话说明该数据没有被他人更新,如果不一致说明数据被他人更新了。

3.如何判断用户是否重复操作;

可以有如下几种方案:

1)数据库层面:添加唯一性约束,通过账号、名称等信息进行唯一性约束;

2)页面层面:可以对操作按钮进行点击限制;

3)后端层面:提交时生成的token(一般是时间戳),存与session,提交到后端与之对比;

4.如何实现实时显示大计算的结果?

5.如何防止重复支付或者重复退款?

6.项目中如防止重复生成订单?

7.项目中遇到什么难题?是如何解决的?

8.下单时,如果在支付的时候,反馈给用户的是失败,然而调用第三方是成功,如何处理?

9.首先要缕清所有的流程,然后再拿出对应的数据表结构

关于分布式

1.分布式框架有哪些?

2.dubbo和spring cloud的比较;

3.Restful风格的接口的理解;

4.rpc框架有哪些?如何使用?

5.rpc和http的对比;

6.负载均衡的理解;

7.常用的mq的种类;(补充)

8.RabbitMQ的作用?

PS(SongLea)

1.一个字符串里有多个左右括号如何判断这些括号都是一一对应的

2.手写一个单例模式的代码

3.手写实现一个blockingqueue的实现

4.线程池的数量怎么确定,设多少?

5.手写怎样实现一个LRU的缓存

6.lru:最少未使用算法

7.redis与rabbitmQ部分知识

8.手写代码去实现一个读写锁

9.代理模式有什么好处,怎么实现的

10.Linux常用命令,如查看磁盘空间,内存大小,CPU利用率,机器信息,Jvm上的内存占用信息。

。。

11.btree树,线程池,数据连接池,秒杀系统设计,回文字符串个数,线程如何变成运行态,事务

的两种方式,垃圾回收机制,索引,hashmap,concurrenthashmap的结构

12.缓存穿透如何解决

13.object有哪些方法,hashmap线程安全不

14.hash一致性,JUC包与sync关键字锁的区别与理解

15.aba的问题;

16.什么是乐观锁?什么是重入锁?

17.CAS操作;

18.常用的集合框架的底层实现;

19.乐观锁和重入锁;

相关主题
文本预览
相关文档 最新文档