360SDN.COM

首页/面试/列表

这里有一份面经,请查收(1)

来源:  2016-10-08 15:55:51    评论:0点击:

链接:http://blog.jobbole.com/103105/

博主毕业快满三年了,由于种种原因想换一份工作。学了 7 年计算机技术,在目前的行业用到的技术不多,还是想去寻找一份互联网行业的工作,这样更能学以致用发挥自己的特长。从上次更新博客到现在已经三周左右了,这三周博客基本断更了,现在找工作也基本收尾了,来聊一聊我所遇到的一些面试经历,希望给各位寻求新机会的小伙伴一个参考。总共面完 8 家收了 7 个 offer,应该算是比较成功的吧。博文中主要还是聊一下技术相关的,博文中所涉及的公司均以代号标志,不便透露细节。

 

第一家面试的公司是一家互联网创业公司,这里简称 D,博主对这家公司的印象还是不错的,共面试了 5 轮,笔试一轮,技术面 3 轮,最后一轮是 HR 面。虽然公司总共员工只有小几百人,但是做事比较专业,很多大型的成熟公司也未必做得更好。

 

首先说说笔试,很多一些小的公司,就是从网上题库中拉点选择题让你做做,之后的面试和笔试题无关,这里我遇到的笔试题是和第一轮技术面相关的,有点小套路。

 

笔试题

 

据博主的回忆,共有这么些题(都是简答题):

 

1. 写出 java 中 synchronized 的使用方式。

可以参考:Java 多线程知识小抄集 (一)

 

2. Java 中设置最大堆和最小堆内存的参数是什么?

-Xmx -Xms

 

3. volatile 的作用?

两点:内存可见性;防止指令重排序;

 

4. 写一个二分查找算法

 

5. 写一个你熟悉的设计模式,画出 UML 图,说出此模式的作用以及写出此模式的主要方法。

 

6. 一道设计题。(略)

 

7. BeanFactory 和 ApplicationContext 的区别。(Sping 的容器可以分为两种类型 :1. BeanFactory:(org.springframework.beans.factory.BeanFactory 接口定义)是最简答的容器,提供了基本的 DI 支持。最常用的 BeanFactory 实现就是 XmlBeanFactory 类,它根据 XML 文件中的定义加载 beans,该容器从 XML 文件读取配置元数据并用它去创建一个完全配置的系统或应用。 2. ApplicationContext 应用上下文:org.springframework.context.ApplicationContext)基于 BeanFactory 之上构建,并提供面向应用的服务。)

 

(第 4,5 题在下面会解释)

 

第一轮技术面

 

主要根据简历以及笔试题进行论述。

 

先将笔试题,首先是写出一个熟悉的设计模式,那当然写个单例咯,这个最简单嘛,主要是 UML 图也特别好画。详细可以参考设计模式:单例模式(Singleton)。博主写的是内部类的写法:

 

public class LazyInitHolderSingleton {  

    private LazyInitHolderSingleton() {  

    }  

 

    private static class SingletonHolder {  

            private static final LazyInitHolderSingleton INSTANCE = new LazyInitHolderSingleton();  

    }  

 

    public static LazyInitHolderSingleton getInstance() {  

            return SingletonHolder.INSTANCE;  

    }  

}  

 

这种写法是懒汉式线程安全的写法。

 

面试官问到一个问题:为什么这种写法是线程安全的?

 

那么这里就设计到一个 JVM 加载的知识:JVM 内部机制可以保证在执行类构造器 () 方法的时候是线程安全的,详细可以参考博文: Java 虚拟机类加载机制。

 

这里博主还特意说了虚拟机规范严格规定了有且只有 5 种情况(JDK7)必须对类进行初始化 (执行类构造器 () 方法):

 

  1. 遇到 new,getstatic,putstatic,invokestatic 这失调字节码指令时,如果类没有进行过初始化,则需要先触发其初始化。生成这 4 条指令的最常见的 Java 代码场景是:使用 new 关键字实例化对象的时候、读取或设置一个类的静态字段(被 final 修饰、已在编译器把结果放入常量池的静态字段除外)的时候,以及调用一个类的静态方法的时候。

  2. 使用 java.lang.reflect 包的方法对类进行反射调用的时候,如果类没有进行过初始化,则需要先触发其初始化。

  3. 当初始化一个类的时候,如果发现其父类还没有进行过初始化,则需要先触发其父类的初始化。

  4. 当虚拟机启动时,用户需要指定一个要执行的主类(包含 main() 方法的那个类),虚拟机会先初始化这个主类。

  5. 当使用 jdk1.7 动态语言支持时,如果一个 java.lang.invoke.MethodHandle 实例最后的解析结果 REF_getstatic,REF_putstatic,REF_invokeStatic 的方法句柄,并且这个方法句柄所对应的类没有进行初始化,则需要先出触发其初始化。

 

尤其是第 5 点,是个特别偏冷的知识点,当你记住这个的时候,可以给面试官留下一个很好的印象。在后面的博文中会经常涉及这种冷知识,可以让你的面试过程添加几处亮点。

 

下面就是要说明一下的二分查找法(首先确保被排序的数组有序),这里有两种写法:递归和非递归的写法。博主憋了一个递归的算法,不过最好还是用非递归的写法。二分查找法还是很容易的,关键这里引申出了变种算法,譬如:给你一个 key,找出这个数组中最左边的 key,或者最右边的 key。当然还有其他变种算法,有兴趣的朋友可以自行查找相关资料。

 

接下去就根据简历聊一聊项目和 Java 基础了。下面稍微列举一些问题:

 

  1. Memcached 和 Redis 的区别? 参考:Redis 和 Memcached 的区别

     

  2. ActiveMQ 的集群配置方式有哪些?(基于共享文件,基于数据库,基于 Zookeeper 等)

     

  3. Mybatis 的一些知识点。(略)

     

  4. 虚拟机的类加载机制。(加载 - 验证 - 准备 - 解析 - 初始化,详细可以参考 Java 虚拟机类加载机制)

     

  5. 内部类相关知识点。

     

  6. 面向对象的设计原则?参考:面向对象的设计原则

     

  7. Spring Aop 的原理?动态代理。

     

  8. Spring 常用的注解?

     

  9. NIO 的相关。参考:攻破 JAVA NIO 技术壁垒

     

  10. 数据库优化相关。(博主基本不直接接触数据库,so 遇到此类问题直接 say: I don’t know. 有兴趣的小伙伴可以自行查阅一些资料,譬如数据访问优化漏斗法则。)

     

  11. linux 下查看文件有哪些方式?cat tac head tail more less nl vim vi gvim

 

技术面二面

 

约好的 10:00 电面,11:30 也没来,后来咨询了 HR 才说面试官出差去了。。。好吧,毕竟公司还在创业初期,管理上有疏忽可以理解。第二次约的 2 面同样是 10:00,这次是 10:27 来的电话。额。。。这此的面试官好像是 CTO,面的也比较深一些:

 

1. 谈谈你对 HashMap 的理解,怎么样去保证线程安全?

 

博主对 HashMap 巴拉巴拉的一阵,可以参考:Java 集合框架:HashMap. 然后有三种方法可以保证 hashMap 的线程安全:换成 HashTable;用 synchronizedMap 包装一下 HashMap; 换成 ConcurrentHashMap。然后补了一句 ConcurrentHashMap 是比较推崇的,然后就被问了另一个问题:说一下 ConcurrentHashMap 的实现原理。然后解释了一下,最后问了个问题:用 HashMap 怎么去实现 ConcurrentHashMap?当时想了一个,觉得不 okay,想说第二个方案就被制止了。现在想想:把 HashMap 用 Collections.synchronizedMap() 包装一下替换屌 Segment 即可。(如果不知所云,请阅读一下 ConcurrentHashMap 的源码先~~)

 

补充:这里还问了平常用了那些线程安全的队列,包括:ConcurrentLinkedQueue, ConcurrentLinkedDeque 以及 BlockingQueue 系列。

 

2.Java 集合中有哪些常用的类?ArrayList 的上级(父类或者接口)是什么,HashMap 的上级又是什么?

 

常用的类:Map 系(HashMap,LinkedHashMap,TreeMap, WeakHashMap, EnumMap 等);List 系(ArrayList, LinkedList, Vector, Stack 等);Set 系(HashSet, LinkedHashSet, TreeSet); 工具类(Collections,Arrays)。这里如果说出来了,就必须对其十分了解,比如博主在另一家互联网公司 W 的面试过程中就被问到:你对 java 集合了解有多少?博主说:我看过所有集合的源码。然后就被问到:Collections.sort() 里面的实现是什么排序算法?这个问题确实够冷门的!幸亏看过,不然就被打脸了。。(TimSort, 加强型归并排序)

ArrayList extends AbstractList implements List, RandomAccess, Cloneable, Serializable. 然后 AbstractList 又继承了 AbstractCollection. 然后 List 和 AbstractCollection 又都 implements 了 Collection.

 

HashMap extends AbstractMap implements Map, Cloneable, Serializable.

 

3.css 导入方式?

 

这个只要 2 周不没看过就会忘记。。博主当时就忘记了。。超简单的题,但是又是最不起眼的题,细节做的不够好。

 

"stylesheet" type="text/css" href="css/head.css" />

 

 

4.js 中的 ajax 操作的方式?这个写的太多了,所以答起来很 easy

 

5. 一句话概括 NIO。博主说了一通,包括 Reactor 模式神马的。但是面试官说:你说的也很对,但是不是我想要的结果。斯巴达。。。

 

6. 设计数据库的一道题,比较简单,不赘述。

 

7. 常用的 linux 命令?(这个被用了好多次了)

 

cat tac head tail more less nl vim vi gvim

date cal man shutdown poweroff reboot echo

uname -r; mount; unmount; exit

cd ls pwd mkdir cp scp rm mv

touch file which whereis locate find tar unzip

grep df top free kill killall

ifconfig ping netstat telnet ftp

passwd umask chrown chmod chgrp sudo ps who

 

8.Spring IOC 的原理?答案:基于反射

 

9. 数据库事务隔离级别?

Uncommit Read; Commit Read; Repeated Read; Serializable.

 

10.memcached 与 Redis 的区别?

 

技术三面

 

之前说过博主对数据库相关的知识,除了会写 SQL 之外,其他的基本白痴。这次面试将近 40mins,差不多被问了 30mins 的数据库的知识。比如:数据库优化;访问多少条数据,数据库的反应延迟是多少;表和视图的区别。

 

当然还有一些其他的,譬如 Spring 中的注解在 xml 文件中怎么配置?

 

context:annotation-config>

 

 

面试过程中有两种问题比较难答:第一种,冷门知识,比如 Colletions.sort() 用到什么排序算法?第二种就是上面的这种特别简单,用过的都知道,但是像这种在 Spring 配置文件中配置完之后就基本不动了,所以特别容易遗忘。

 

还有类似的比如:Spring 中的自动装配怎么配置?

 

context:componenet-scan>

 

 

HR 面

 

最后是 HR 面,这个最简单,只要言语不过激都是 okay 的,主要谈谈在原来公司主要做什么,为什么要换份新工作,期望薪资神马的。

 

(ps: 谈薪资是门艺术,同样两个人,面试打分也是一样的,但是薪资会谈和不会谈之间可能相差很多,这门艺术博主还在研究中,虽然有所收获,但是还是不敢出来卖弄,等博主把人事六大块之一的薪酬领悟之后再来探讨探讨。)

 

总结

 

博主总结几个心得,仅供参考:

 

面试第一要素:不要紧张,如果你真是技术族,而且对技术有所痴迷,一聊起技术来根本不会紧张。

 

面试第二要素:要对简历上的内容了如指掌,包括原理源码,如果略懂或者根本就是用了几天就再也没用过的技术就从简历上删掉吧,否则被面试官抓住不放就糟糕了。

 

面试第三要素:学会引导面试,掌握主动权。这门技艺需要多去混点面筋,然后自我优化之后,一般都可以掌握。

 

面试第四要素:做人要低调。面试你这个职位的人的技术肯定比这个职位高好几个 level, 不要觉得你回答了你非常熟悉的问题就高调起来,面试官随时可以挖出一堆坑来让你往里面跳。

 

面试第五要素:要自信。有些面试官会对某些你回答完问题之后会补一句:你确定?这时候就要看你自己了,有可能面试官再提醒你,也有可能再诈你。归根结底还是要技术掌握的够硬,底气就足一些。

 

参考资料:

1. Java 多线程知识小抄集 (一)

2. 设计模式:单例模式(Singleton)

3. Java 虚拟机类加载机制

4. Redis 和 Memcached 的区别

5. 面向对象的设计原则

6. 攻破 JAVA NIO 技术壁垒

7. Java 集合框架:HashMap

这里有一份面经,请查收(2)

这里有一份面经,请查收(3)
为您推荐

友情链接 |九搜汽车网 |手机ok生活信息网|ok生活信息网|ok微生活
 Powered by www.360SDN.COM   京ICP备11022651号-4 © 2012-2016 版权