恒生面试小结

来源:互联网 发布:路由器网络限速的比例 编辑:程序博客网 时间:2024/04/28 15:01

题外话

今天参加了恒生面试,一如既往的酒店面试。不同的是,这次是群面,第一次群面,所以我也认真听完了其他六个人的自我介绍和技术问答。概括来看,他们都有一个特点:知识水平大多停留在大学课程,有过一两次比赛经历,英语通过了四级,有一些体现“领导力”的社会实践;同时也不善言辞,或者不够自信,语言内容有时甚至会出现纰漏。有时候我会对这种无主见将自己刻意塑造为某种形象感到惋惜。引以为戒。

面试问题

  1. 知道jvm gc过程吗?
  2. 能具体谈谈jvm的参数设置有那些吗?
  3. 什么是内存泄漏(结合内存溢出)来谈?
  4. 假如发生内存泄漏,继续强制执行垃圾回收会发生什么,比如说显示的调用的System.gc()?

QS1. 通过可达性分析的无用的对象,会首先被标记,以确定对象是否需要执行finaliize()方法;
之后会进行一次筛选,如果对象覆盖了finalize()方法,同时finalize()没有被其他虚拟机调用,则该对象在此被标记;
通过了第二次标记的对象会加入一个F-Queue的队列,同时等待一个由虚拟机自启的,低优先级的Finalizer线程去执行gc;
[执行:这里的执行只能保证触发,并不保证会虚拟机会等待它执行完成]
[自我拯救:在第一次标记后,线程仍然有机会去和可达性分析可以到达的线程建立联系,来再次使自己免于被回收]



QS2. 典型设置:
java -Xmx3550m -Xms3550m -Xmn2g -Xss128k
Xmx3550m :设置jvm的最大内存为35550M;
Xms3550m :设置jvm的内存促使内存为35550M,此值一般与Xmx的值相同;
Xmn2g:设置jvm年轻代的内存大小。堆大小=年轻代+老年代+持久代;
Xss128k:设置每一个线程占用内存的大小。正常情况下为1M,可以创建3000~5000个

java -Xmx3550m -Xms3550m -Xss128k -XX:NewRatio=4 -XX:SurvivorRatio=4 -XX:MaxPermSize=16m -XX:MaxTenuringThreshold=0
-XX:NewRatio=4:设置年轻代(包括Eden和两个Survivor区)与年老代的比值(除去持久代)。设置为4,则年轻代与年老代所占比值为1:4,年轻代占整个堆栈的1/5
-XX:SurvivorRatio=4:设置年轻代中Eden区与Survivor区的大小比值。设置为4,则两个Survivor区与一个Eden区的比值为2:4,一个Survivor区占整个年轻代的1/6
-XX:MaxPermSize=16m:设置持久代大小为16m。
-XX:MaxTenuringThreshold=0:设置垃圾最大年龄。如果设置为0的话,则年轻代对象不经过Survivor区,直接进入年老代。 对于年老代比较多的应用,可以提高效率。如果将此值设置为一个较大值,则年轻代对象会在Survivor区进行多次复制,这样可以增加对象再年轻代的存活 时间,增加在年轻代即被回收的概论。

归纳
java内存分为四个区域:
1. 虚拟机栈;用于创建方法栈帧
2. Native栈:其他语法的方法栈
3. 方法区:存放常量,


QS3. 内存泄漏我之前的博客中谈过,但是面试时候没有完整回答出来;
内存泄漏前述
简单来说就是:对象非法持有内存未释放;
回答上面的问题,如果发生内存泄漏时调用gc,其实是徒劳的。因为根据内存泄漏的定义发生内存泄漏的对象仍然是可达的。至于之后是否会发生 OOM暂时不清楚。


5.使用过数据库连接池吗?和常规的数据库连接有什么优势?
6.数据库连接池有哪些参数需要设置?最小连接数的设置有什么影响吗?
7.如果将连接反应时间设置为0会发生什么?


QS5. 数据库连接池主要分为DBCP和c3p0。DBCP是tomcat的默认数据库连接池,c3p0是更主流的数据库连接池(hibernate框架的默认连接池),相比较而言c3p0不但能够自动处理垃圾连接,还能自动处理无用的Statement和ResultsSet;

c3p0示例:

        ComboPooledDataSource cpds=new ComboPooledDataSource();        cpds.setDriverClass("com.mysql.jdbc.mysql");        cpds.setJdbcUrl("jdbc:mysql://localhost:3306/javaee");        cpds.setUser("root");        cpds.setPassword("root");        cpds.setMaxPoolSize(20);        cpds.setMinPoolSize(2);        cpds.setInitialPoolSize(10);        cpds.setMaxStatements(180);        Connection connection=cpds.getConnection();

QS6. 最小连接数的保证了初始的连接数,如果应用程序对数据库的需要不大时,开启较少的数据库连接能够保证资源不被浪费。

QS7. 如果将连接的响应时间设置为0,这个我自己尝试之后再来补充吧


8.Eclipse的快捷键操作有哪些? 看这里
9.操作系统缓存,内存硬盘的调度算法有哪些?
内存调度:OPT LUR FIFO CLOCK
硬盘调度:FIFO SSTF SCAN C-SCAN
(能够描述清楚上述算法的原理:详细)

原创粉丝点击