龙空技术网

Java大佬两年的面试经验

java小悠 842

前言:

今天大家对“java一年经验面试题”大概比较看重,姐妹们都想要了解一些“java一年经验面试题”的相关内容。那么小编在网摘上搜集了一些关于“java一年经验面试题””的相关内容,希望朋友们能喜欢,各位老铁们一起来了解一下吧!

一:面试中的问题

二: 面试中要注意的问题

三:关于最后的选择

四:两年java到底应该具备什么样的水平

一:面试中的问题

java集合框架:

1:介绍一下java的集合框架

2:HashMap遇见哈希冲突会如何怎么办?HashMap是线程安全的吗?HashMap在高并发下会有什么问题?然后引入ConcurrentHashMap的原理?

3:Hahtable和concurrentHashMap的区别?

4:数组和ArrayList的区别?Arraylist是如何扩容的?

5:线程池中的阻塞队列一般会选择哪种队列?为什么?

6:RetreenLock的原理?AQS的原理?

7:HashMap的容量为什么推荐是2的幂次方?

框架类:

1:mybatis的二级缓存有什么问题?

2:mybaits中的mapper的#{}和${}有什么区别?哪种可以防止sql注入?

2:我们知道mybatis的mapper和接口之间是没有对象的,那么它是如何映射的?

4:说说springmvc的注解有哪些?他们的原理是什么?

5:springmvc的控制器是单例的吗?是线程安全的吗?

6:struts1和struts2的区别?是线程安全的吗?

7:spring如何解析它的xml文件?

8:spring的核心是什么?Aop的原理是什么?

redis相关:

1:redis数据类型有哪些?

2:zset数据类型是如何排序的?

3:redis如何做项目的中间缓存层?

4:redis的Hash的时间复杂度是多少?

数据库:

1:数据库索引分为哪几种?组合索引有什么要注意的问题?

2:什么是悲观锁 什么是乐观锁?如何实现悲观锁?

3: 数据库关键字的执行顺序是什么?

4:如何进行sql优化?

5:有没有进行过分库分表操作?分库之后如何保持事务一致?

分布式和微服务:

1:微服务要克服那些问题?微服务系统是怎样通信的?

2:分布式环境下如何解决session不一致的问题?

3:分布式下如何保证id一致?

4:你在dubbo的使用过程中遇到什么问题?

5: zookeeper的负载均衡算法有哪些?

jdk源码相关

1:synchronized的原理?它该怎么用?如何一个方法是synchronized的,其他的非synchronzied线程能进入吗?

2:cvs中的ABA问题如何解决?

3:volatile的原理是什么?volatile一定是线程安全的吗?

4:ThreadLocal是什么?它的原理是什么?

5:CountDowanLatch有没有用过?适合在什么样的场景下用?

设计模式相关:

1:实现两种单例模式

2:讲一下观察者模式

3:spring中都用到哪些设计模式?

4:动态代理模式是如何实现的?

5:你在项目中用到哪些设计模式了?讲解一下业务场景

算法相关:

1:快速排序的时间复杂度?手写快速排序(注意递归式和非递归式的实现方式)

2:手写二分查找

3:手写堆排序

4:一个int数组如何进行奇数和偶数分离?

5:用算法实现String转double

jvm相关

1: jvm的垃圾回收算法有哪些?分别解释一下?

2: 新生代为什么要设置两个survior区?

3:如何通过一个.class文件获取它的jdk版本?

4:jvm的内存模型?哪些是线程私有的?哪些是公共的?

关于自己的项目(问的时间最长)

1:简述一下自己的项目?你在其中主要是做什么的?

2:你在项目中都遇到了哪些难题?最后都是怎么解决的?

3:项目有多大规模?周期多久(这个很多都问到的)

4:讲一下某一模块的具体实现方式?然后从中挑刺

5:如何解决某一时刻的高并发请求?

6:如何解决订单支付回调的超时问题?轮询应该怎么写?

其他:

1:秒杀场景如何削峰?

2:http和udp的区别是什么?

3:ajax的跨域问题

4:nio与io的区别?什么情况下适合用nio

5: 说说常见的linux命令,linux查看内存的命令是什么?

7:git遇见代码冲突了怎么办?

8:说几个常见的maven命令,maven如何排除一个jar包的冲突?

二: 面试中要注意的问题

2.1:一定要有自己的实际项目经验

按照我这么多面试经验?其实有的公司会侧重于问自己做的项目经验,有的公司侧重于问问题,一般互联网公司会对技术要求比较高,既要求项目经验又要要求技术水平

2.2:可以适当渲染,但是不要夸大其词

面试的过程中最忌讳的就是夸夸其谈,高屋建瓴很厉害,但是一到实际细节都不知所云了,在技术总监面前,其实你吹牛或者是真的会他是一目了然的。不懂装懂,有的面试官又给你台阶下,不然你就卡带了,这很容易造成面试的不好印象

2.3:要会自我介绍

面试的时候一般的话都会让你做一个自我介绍,这个要分对象,是技术官还是Hr,如果是技术官侧重于综述一下自己的项目的实际技术栈和技术路线,如果是Hr的话不要用过多的技术语言,而要说一些自己的实际工作经历或者自己上家公司的运营情况

2.4:关于简历

简历切记不可太啰嗦,但是不可太简单,作为技术的简历一般起码得在3页,不然HR会觉得你的求职态度不怎么好,不管如何求职结果如何,一个良好的简历会给人留下好的第一印象

三:关于最后的选择

说实话也接受到很多HR的offer邀请,但是我一般会选择说考虑一下一天以后再给回复,切不可直接把话说死,不然后面就尴尬了。实际提供的offer的有一家外包公司,三家创业公司,两家互联网公司,最终选择了一家互联网公司,虽然实际上班地点有点远(下了地铁还得座公交,后来还是选择骑单车了),但是互联网公司会给你快的成长速度,并且互联网技术栈都比较新..相比于传统企业会有更多的技术挑战。而外包公司的话,可能环境不怎么好,我记得自己当初还是个小白的时候,去了外包,那里的优点就是会有不断的活,新人进去的话收获还是挺多的,但是作为已经有两年经验的我,外包很显然不适合我的后期职业发展。缺点:技术更新迭代的太慢,没有归属感,最后的选择我个人的意见是选择技术优先,毕竟以后软件路还长,技术才是王道

四:两年java到底应该具备什么样的水平

两年java的面试过程中遇到了很多挑战,也遇到了一些不谈技术的公司,从上面的面试题可以看出,目前对于java的要求越来越高,水涨船高,毕竟这个行业的人数越来越多,而保持自己的竞争力的唯一方法就是找对方向,不断学习,注意这里我提到的第一点是方向,然后才是学习。给自己制定一个职业规划,按照这个路线往前走,我其实还在想分布式微服务这块以后再深入学习,可是按照市场要求,现在已经刻不容缓了,一些技术架构比如:springcloud、duboo都得保持学习,这样才能有竞争力!作为一名两年的javaSir,你必须具备以下技能

1:阅读源码的能力,多用Intelj idea这个开发工具,而不是eclipse。它是直接支持反编译class文件的,多读jdk源码,吸收优秀的源码并加以复用

2:做到能够手写常见的排序算法,比如快速排序和堆排序、冒泡排序、选择排序、二分查找这些都是必须的

3:对java的框架有很深入的认识,现在基本流行的ssm框架很多人都会,可是知道一些原理的人就不多了,得不断研究这些框架本身,它们都是经过无数次锤炼 出来的优秀框架

4:多用redis\mongodb,传统的关系型数据库已经无法市场需求了,这些东西也是面试中的一部分,虽不是重点,但也是加分的选项

5:对于微服务和分布式,这个是有一定难度的,我在面试人人车的时候,一面很顺利,二面被技术总监给pass了,问题就是分布式不是特别熟悉!要想进入好的互联网公司,分布式和微服务是很必须的

6:jvm的底层,这里要推荐的书就是周志明的《深入jvm虚拟机》这本书了,我总在闲暇时间读它,所以jvm的问题还是信手拈来的

小编还整理了许多的java面试资料。如有需要的小伙伴可私信“面试”给小编即可获取哦

标签: #java一年经验面试题 #java面试谈优点缺点