【283期】熊大同学的面试回忆录(2.5年开发经验)

>>强大,10k+点赞的 SpringBoot 后台管理系统竟然出了详细教程!

【283期】熊大同学的面试回忆录(2.5年开发经验)

今天去看牙医,他问我年级轻轻牙齿怎么磨损这么严重?我说,没有点赞的这些年,我都是咬着牙过来的。

以下为读者面试后的分享,部分回答笔者做了一些补充整理,希望对你有帮助。(两年左右开发经验,不具有共性,仅供参考!)

PS:如果各位同学在面试后,也会做一些整理总结,也欢迎联系我,整理分享在公众号上,互帮互助,帮助找工作的同学拿下心仪公司的Offer!

1.自我介绍

各有不同,略。(话说回来,如果是不善言辞的同学,应该面试前给自我介绍打个底稿记一下,开局印象也重要,自我介绍都结结巴巴的,面试要凉一半!)


2.之前项目中使用过哪些框架,评价一下自己掌握的程度?

答:Spring,SpringMVC,SpringBoot,Mybatis,SpringCloud那一套,基本都使用过。

掌握程度的话,基本上在搭建及使用上没有问题,具备独立开发的能力,但是因为之前公司开发任务比较紧张,暂时对底层原理这些没有做太多的研究。

ps:如果你对Spring全家桶这套底层源码、实现原理等有较深的研究,感觉能经受得住提问,就不要这样自我评价了~


3.你们的微服务项目,服务注册、发现使用什么组件?

答:使用了Nacos。

接着问了为什么没有用Eureka,他们有什么区别吗?

答:Nacos可能更有先进性一些,自带实现配置中心,Eureka的话,需要整合SpringCloud Config,同时Nacos支持根据不同的业务、环境进行分组管理,所以在选型上有限考虑了Nacos。

PS:附Eureka和Nacos的功能对比图

【283期】熊大同学的面试回忆录(2.5年开发经验)

4.那你知道Nacos的实现原理吗?

没答出来。

回答了:平时业务开发比较多,比较熟悉使用,对底层原理没有做深入的了解。

ps:Nacos原理分析,可以看这里:

【282期】面试官:你能说说 Nacos 的实现原理吗?

5.你觉得SpringBoot和Spring的区别是什么?

答:SpringBoot开发中简化了很多XML的配置,引入自动配置的概念,做到零配置开箱即用。

还有就是内置了容器,不需要配置Tomcat,可以直接打包Jar运行。

接着问了SpringBoot的启动原理

答:通过@SpringBootApplication注解启动初始化模块,加载基本的环境变量、资源、构造器等,配置信息等;根据文件中配置的 Jar 包去扫描并加载项目所依赖的 Jar 包;@SpringBootApplication注解包含@ComponentScan注解,可以进行组件扫描,把扫描到的Bean注入到注入 Spring Context 中,完成SpringBoot的启动!

PS:这个问题回答的很虚,面试之前其实看过SpringBoot启动原理的文章,但是没有自己去提炼一下如何回答(没想到就问了,心里那个悔啊),不过面试官没有说什么,回答完后直接问了另一个问题。

6.Spring中用了哪些设计模式?

答:工厂模式、代理模式、单例模式。

我是个菜鸡,平时设计模式其实研究不多,偏重业务开发。答完后面试官追问还有呢?我回答暂时想不到了!!!

接着问,具体说说哪里用到了?

  • 工厂模式在BeanFactory以及ApplicationContext创建中都有用到;
  • 代理模式在Aop实现中用到了JDK的动态代理;
  • 单例模式在创建bean的时候,默认单例;

面试后的总结:设计模式上肯定失分了,其实也看过这类文章,还有收藏,只是没有深入去阅读,总结,导致面试回答时候,能想起一点,但是总是回答不全或者回答不到点子上,以后学习的习惯要改,不能草草看过就算,要么不看,看过就记录总结~~

7.熟悉Linux操作系统吗?

答:熟悉,项目部署一直使用linux,基本的项目部署之类没有问题。

接着问说说常用的Linux命令

  • vim 打开文件修改内容

  • find 搜索文件

  • mkdir 创建目录

  • rm 删除目录或文件

  • kill 杀掉进程

  • cp 拷贝

等等,说了不到十个左右被打断,问了:

  • 查看与某台机子的连接情况:ping ip
  • 重启网络:service network restart

让自己说了一通常用的命令之后,只问了这两个。

8.Redis熟悉吗?用得多吗?

答:项目中一直在用,还算熟悉。

说说Redis的常用命令吧

  • info:提供服务器的信息和统计;

  • shundown:将数据同步保存到磁盘,然后关闭服务;

  • get(key):返回数据库中名称为key的string的value;

  • setnx(key, value):添加string,名称为key,值为value;

  • lindex(key, index):返回名称为key的list中index位置的元素;

简单说了几个,接着问了 什么是缓存穿透、缓存雪崩、缓存击穿?

缓存穿透、缓存雪崩、缓存击穿的解决方法?

我感觉这个回答的还行,答案不罗列了,参考:

PS:主要是看过,也理解了这部分,其实这个在之前项目中还真没实际处理过~~~

9.Excel数据的导入导出处理过吗

答:处理过,使用了POI做Excel的导入导出。

接着问导出数据量很大,会有什么问题

答:会导致内存溢出。

你们怎么处理的?

(这个基本没答上来,依稀记得看过公众号相关文章,但是忘记的死死的,好想说我去找个文章,拷贝一下人家处理的代码,这样子解决。)

答:之前项目中,导出没有遇到数据量特别多的场景,没有这方面的处理经验。

10.有没有对项目做过优化,说说SQL方面你们一般会做哪些优化处理

答:

  • 使用连接(JOIN)来代替子查询;
  • 对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引;
  • 用EXISTS替代IN、用NOT EXISTS替代NOT IN;
  • 避免在索引列上使用计算;
  • 应尽量避免在 where 子句中对字段进行 null 值判断,否则将导致引擎放弃使用索引而进行全表扫描;
  • 尽量避免3条以上的Join查询;

接着问,很多次说到索引,是不是添加的索引越多越好?

答:不是。

  • 表记录太少
  • 经常插入、删除、修改的表

补充:

  • 数据重复且分布平均的表字段,假如一个表有10万行记录,有一个字段A只有T和F两种值,且每个值的分布概率大约为50%,那么对这种表A字段建索引一般不会提高数据库的查询速度。
  • 经常和主字段一块查询但主字段索引值比较多的表字段

其他

问了一些简历上的项目问题,不具备共性,这里不分享了。

问了能手写红黑树吗?

答:数据结构那些不太熟,只会基本的排序那些,面试官一笑~

问了在之前项目中有没有踩过什么坑,怎么解决的?

最怕这类提问,想了一下说了事务注解失效的坑,导致生产数据出现问题,熬夜回退并作了数据矫正。

问了上家公司离职原因

回答不具有共性(本人是一线城市回二线),略。

问有什么想问的吗?

问了对我面试表现的评价。评价大意是项目实战经验不错,使用的技术方面都比较契合,项目上没有问题;然后Java基础方面不理想,知道使用但是对原理没有去做了解。

嗯,还算中肯~~

基本面试下来,回想起来的就这些问题了。但是提问顺序有出入,记性不好,只能回忆期这些了,希望对你有所帮助!

END

十期推荐

【271期】面试官:Spring MVC的处理流程是怎样的?
【272期】数据结构:哈希表原理以及面试中的常见考点
【273期】告诉面试官,我能优化groupBy,而且知道得很深!
【274期】面试官:怎么保证缓存和数据库一致性
【275期】面试官:你对MySQL中的索引了解多少?
【276期】面试官:你分析过@Annotation注解的实现原理吗?
【277期】面试官:说几种常用的分布式 ID 解决方案
【278期】面试官:都说 select * 效率低下,你知道什么原因吗?
【279期】面试官:Java遍历Map集合有哪几种方式?各自效率怎么样?
【280期】k8s面试问什么?

与其在网上拼命找题? 不如马上关注我们~

【283期】熊大同学的面试回忆录(2.5年开发经验)

原文始发于微信公众号(Java面试题精选):【283期】熊大同学的面试回忆录(2.5年开发经验)