首页 > Java常见面试题(七)
头像
小谢backup
编辑于 2021-03-11 19:31
+ 关注

Java常见面试题(七)

1、过滤器和拦截器的区别?

1)过滤器依赖Servlet;拦截器依赖Web框架如SpringMVC,能起到AOP的效果,通过拦截器可以实现动态代理。

2)过滤器基于函数回调;而拦截器基于Java的反射机制。

3)过滤器可以过滤各种请求,而拦截器只能拦截Controller请求,对诸如直接访问静态资源的请求无能为力。

4)过滤器比拦截器先执行。

5)在一次请求的生命周期中,拦截器可以多次被调用,并且使用很灵活;而过滤器只能在容器初始化时被调用一次。


2JVM的组成部分有哪些?

类加载器(ClassLoader)

运行时数据区(Runtime Data Area)

执行引擎(Execution Engine)

本地库接口(Native Interface)


3JVM的运行时数据区分为哪五大部分?

堆、栈、本地方法栈、方法区、程序计数器


4、新生代垃圾回收器和老生代垃圾回收器都有哪些?有什么区别?

新生代回收器:Serial、ParNew、Parallel Scavenge

老年代回收器:Serial Old、Parallel Old、CMS

整堆回收器:G1


新生代垃圾回收器一般采用的是复制算法,复制算法的优点是效率高,缺点是内存利用率低;老年代回收器一般采用的是标记-整理的算法进行垃圾回收。


5Minor GCFull GC分别在什么时候发生?

新生代内存不够用时候发生Minor GC,

Minor GC失败或者JVM内存不够的时候发生Full GC。


6volatile i++线程安全吗?

不安全。


原因:Java中只有对基本类型变量的赋值和读取是原子操作,如i = 1的赋值操作,但是像j = i或者i++这样的操作都不是原子操作,因为他们都进行了多次原子操作,比如先读取i的值,再将i的值赋值给j,两个原子操作加起来就不是原子操作了。


7CMS为什么采用标记——清除算法?

CMS主要关注低延迟,因而采用并发方式,清理垃圾时,应用程序还在运行,如果采用压缩算法,则涉及到要移动应用程序的存活对象,此时不停顿,是很难处理的。

一般移动存活对象是需要停顿的,再让应用程序继续运行,但这样停顿时间变长,延迟变大,不符合CMS低延迟的运作模式,所以CMS采用清除算法。


8、成员变量和静态变量分布存在哪里?

成员变量存在堆中,静态变量存在方法区中。


9、反射有哪三种做法?

假设 Foo  foo=new  Foo();

1)通过Object的getClass方法:Class cla = foo.getClass()

2)通过对象实例获取:Class cla = foo.class

3)通过Class.forName方式:Class cla = Class.forName( "xx.xx.Foo" );


10ArrayList是线程不安全的,轻量级的。如何使ArrayList线程安全?

1)继承Arraylist,然后重写或按需求编写自己的方法,这些方法要写成synchronized,在这些synchronized的方法中调用ArrayList的方法。

2List list = Collections.synchronizedList(new ArrayList());

内容来源公众号:小谢backup

全部评论

(0) 回帖
加载中...
话题 回帖

推荐话题

相关热帖

近期热帖

近期精华帖

热门推荐