恒生面试小结

题外话

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

面试问题

  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
(能够描述清楚上述算法的原理:详细)

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值