Java中高级面试题(附答案)[java面试题]

内容摘要
1、redis如何跟本地数据同步?程序实现mysql更新、添加、删除就会同步操作redis程序查询redis,不存在就查询mysql,自动保存redis2、redis几种数据结构?set、list、hash、string、
文章正文

1、redis如何跟本地数据同步?

程序实现mysql更新、添加、删除就会同步操作redis

程序查询redis,不存在就查询mysql,自动保存redis

2、redis几种数据结构?

set、list、hash、string、zset

3、java内存溢出是如何造成的?

OutOfMemoryError:

(1)PerGern Space 程序中使用了大量的jar或class,使虚拟机装载类空间不够。

解决方案:调参 XX:PermSize 和XX:MaxPermSize、减少jar包减少类的重复加载

(2)Java Heap

Space Java虚拟机创建太多对象。 解决方法:调参Xms(初始化堆大小)Xmx(最大堆大小)、检查死循环或不必要创建的重复对象。

(3)unable to create new native Thread

JVM占用了太多内存空间,而在JVM中创建线程还要再操作系统中创建线程。 解决方案:调整JVM中线程大小。

4、String s = “123”,这个语句有多少对象产生?

若字符串池中没有“123”,则产生一个,并且放入常量池中,若有“123”,则产生0个

5、JDK8的新特性,举例描述

(1)lambda表达式:函数式编程,方法的引用

(2)Stream API

(3)接口的默认方法

(4)日期时间API的改进,新增DateTimeFormatter方法

6、解决高并发和高负载

(1)尽可能html静态化,采用信息录入发布系统CMS实现信息录入自动生成静态页面,在前端缓存不经常改变的动态数据。

(2)CDN加速,把CSS/JS等资源分布在不同的服务器上

(3)缓存不常改变的数据(Redis、memcache)。

(4)图片服务器与应用服务器分离。

(5)集群

7、生产者和消费者模型得瑟作用是什么?

(1)通过平衡生产能力和消费者的消费能力来提升整个系统的运行效率 (2)解耦

8、Mybatis一级、二级缓存

(1)一级缓存:基于PerpetualCache的HashMap本地缓存,其存储作用域Session,当Session

flush或close之后,该Session中的所有Cache就将清空。

(2)二级缓存与一级缓存机制相同,默认也是采用PerpetualCache,HashMap存储,不同在存储作用域Mapper,并且可自定义存储源,如需开启二级缓存。在sql映射文件添加

9、描述一个服务从发布到被消费的详细过程

首先获取zk的配置信息,然后获取需要暴露的url,然后调用registry,register方法将url注册到zookeeper上去

10、如何实现负载均衡,有哪些算法可以实现?

随机(random)、轮训(round-robin)、一致哈希(consistent-hash)和主备(master-slave)

11、如果要你实现Spring AOP,怎么实现?

实现aop技术,主要分为两大类:一采用动态代理技术,利用截取消息的方式,对该消息进行装饰,以取代原有对象行为的执行

二是采用静态织入的方式,引入特定语法创建“方面”,从而使得编译器间织入有关“方面”的代码

12、如何防止页面重复提交?

集群环境:采用token加redis(redis是单线程的,处理需要排队)

处理流程:

1、数据提交前要向服务申请token,token放到redis内存,token有效时间

2、提交后后台校验token,同时删除token,生成新的token返回

13、什么是微服务?

将工程根据不同的业务规则拆分成微服务,部署在不同的机器上。服务间进行相互调用

14、什么是web服务?

(1)web service就是一个应用程序,它向外界暴露出一个能够通过web进行调用的API

(2)基于HTTP协议传输数据,这使得运行在不同机上的不同应用程序,无需借助附加的、专门的第三方软件和硬件,就可以相互交换数据或集成

15、谈一下你的项目选择Struts2的理由?

①Action是POJO类,没有依赖Servlet API,具有良好的可测试性; ②强大的拦截器,简化了开发的复杂度;

③支持多种表现层技术:JSP、Freemarker等; ④灵活的验证方式; ⑤国际化(I18N)支持 ⑥声明式异常管理;

⑦通过JSON插件简化Ajax; ⑧通过Spring插件跟Spring整合;

16、谈一下拦截器和过滤器的区别?

拦截器和过滤器都可以用来实现横切关注功能,其区别主要在于: ①拦截器是基于JAVA反射机制的,而过滤器是基于函数回调的

②过滤器依赖于Servlet容器,而拦截器不依赖于Servlet容器

③拦截器只能对Action请求起作用(Action中的方法),而过滤器可以对几乎所有的请求起作用(CSS JSP JS)

17、Spring支持的事务管理类型?

编程式事务管理:编程的方式管理事物,极大的灵活性,难维护

声明式事务管理:可以将业务代码和事物管理分离、只需要用注解和XML配置来管理事物

IDC笔记,大量的免费Java入门教程,欢迎在线学习!

代码注释
[!--zhushi--]

作者:喵哥笔记

IDC笔记

学的不仅是技术,更是梦想!