1.自我介绍
2.左连接(a表左连接b表,a表全部数据出来,b表没有的数据为空)
3.a表左连接b表,b表左连接c表,c表左连接a表,这样的数据是什么数据(博主当时有点懵,回答全连接,全部数据会出来。。。)
4.sql:一个班的学生有两个字段,一个字段叫分数,另外一个字段叫组名,有4个组,查出每个组的第一名,sql怎么写
select group_name,max(score) from table group by group_name order by group_name
5.数据库引擎有哪些(myIsam,InnoDB等等)
6.myIsam和InnoDB的区别(InnoDB支持事务,外键,奔溃后恢复,InnoDB行级锁,myIsam表级锁)
7.myIsam的优点(博主当时只记住了InnoDB的优点,没想到面试官问到了myIsam的优点,速度快,磁盘空间占用少)
8.Spring的两个特性(IOC和aop,这两个特性用到了哪些设计模式)
9.java的容器,集合(老生常谈了,list, set, map等等,另外说一下有哪些实现类)
10.hashmap的实现(数组+链表+红黑树)
11.put一个key和value,怎么确定数组的下标,如果有两个key put到同个位置,怎么做?(根据key计算hash值,根据hash确定下标等等)
12.是线程安全的吗?有哪些实现?(不是,线程安全的可以用hashtable,concurrentHashMap等等)
13.concurrentHashMap是怎么实现线程安全的?具体的实现?两个线程同时put 两个key是怎么做的?
(1.7数组+链表,分段锁,1.8数组+链表+红黑树,cas+synchronized)
14.java集合的排序(stream中的sort),内部是怎么实现的?原理是什么?了解过哪些排序?
(Comparable和Comparator 参考链接)
15.java集合的分组(groupingby (对象::属性))
16.函数式方法(接口),什么条件下才能用?这种适用于所有的吗?还是说有一定的限制?
17.后台的请求比较慢,一般是什么原因造成的?后台请求直接卡了,怎么排查,日志没报错呢?(查一下慢sql,需要大量运算)
18.怎么查锁日志,线程日志?(这个不知道)
19.常见线程池,这些都是什么样的线程池?(newCachedThreadPool,newFixedThreadPool,newScheduledThreadPool,newSingleThreadExecutor,现在有6种线程池了,没记那么多)
20.java锁,并简单说一下锁,类名,关键字,锁的实现等等(ReentrantLock,迷迷糊糊说了一些,毕竟记得不多)
21.谷歌guava缓存用过吗?(没用过)
22.项目有哪些难的实现,你是怎么做的?(根据自己的情况去回答)
过去面试的时候,是星期五晚上8点多了
简单自我介绍,对技术,薪资有要求什么的,跳槽原因,评价自己,公司加班挺多的,问能不能接受
1.对称加密和非对称加密的区别
2.跨域脚本攻击(还有好几个没听过)
3.数据库隔离级别(读未提交,读已提交,可重复读,串行化)
4.不可重复读和幻读是什么?(a重复读同个数据,b修改数据,a再次读,就是不可重复读;a修改某些数据,b从中插入一条数据,a会发现还有一条数据没修改,那么就是幻读)
5.死锁是什么?产生原因?怎么解决(竞争同一资源,四个条件,破坏四个条件,这一块没答好)
6.服务器cpu百分百,怎么排查(ps查看进程,答的不是很好,毕竟这方面没研究。虽然公司也遇到了cpu百分百的情况,但是解决办法是把需要大量运算的mrp功能给禁掉,后面加内存,加服务器。这一块我可不敢实话实说)
7.nginx可以用来做什么(负载均衡,反向代理,面试官还继续问还有呢,我不知道什么了,我说可以拦截ip等等)
8.cas是什么?(乐观锁的一种实现,会造成aba问题,加版本号或者时间戳)
9.redis持久化机制,rdb和aof的优缺点(全量数据备份,安全性低,备份间隔时间长;增量数据备份,数据安全,文件大)
10.spring异步注解(没用过)
11.讲一讲类加载机制
12.内存泄露和内存溢出的区别
13.还问了其他一些题目,不太记得了
14.讲一讲项目,你是怎么做的
看到一个小姐姐,问路,好漂亮
进去之后,填资料,填完资料,就问问题
1.mysql的常用引擎,区别(InnoDB:支持事务,外键,行锁,支持奔溃后恢复,面试官还问为什么能恢复。Myisam: 表锁,全文索引)
2.sql有哪些优化,常用索引(查询哪些字段,不要用*, null, like后面的"% 等等)
3.sql语句执行的过程是怎么样的?怎么分析explain
4.假如有100w数据,我想要第60万行之后的数据,怎么优化(用limit,加索引,面试官太变态了,问加了这些还很慢,怎么办)
5.redis是什么,为什么比mongodb热门?(非关系型数据库,基于内存等等,为什么热门,这个我就说不知道了,因为不知道mongodb)
6.什么是非关系型数据库,与关系型数据库的区别?(没回答好)
7.除了基于内存,读取速度快,还有哪些原因让redis快?(没回答好)
8.常用的数据类型,应用场景(String,List,Set,Zset,Hash,面试官还问为什么,额,简直是抽丝剥茧呢)
9.持久化机制,rdb和aof的区别,你会怎么选择哪种机制(全量和增量,备份时间长短,数据安全等等,现在有混合机制)
10.淘汰策略有哪些(答到过期策略那里去了,面试官提醒了)
11.redis为什么可以对 String 进行自增自减运算(这个不知道)
12.redis怎么进行优化?(不知道)
13.java常用的集合有哪些?(list,set,map,实现类)
14.arrayList和linkedList的区别(数据结构,读取和增删速度,线程安全copyonwriteArrayList)
15.我想要插入几十万数据到arrayList,有什么优化方法?(这个还真的不知道了)
16.hashmap底层结构,put的过程?为什么要加红黑数?结构全部用红黑树可以吗?(数组+链表+红黑树,根据key计算hash,根据hash计算下标,下标为null就赋值,不为null,就遍历判断hashcode相等等等,1.7用头插,1.8用尾插,加红黑树是稳定,效率。数组查询时间复杂度o(1),链表增删时间复制度o(1),红黑树o(log n),效率没有前面两者高,所以,不能全部用红黑树)
17.concurrenthashmap的结构(1.7分段锁,1.8cas+synchronize)
18.synchronize和lock的区别
19.hashtable和concurrenthashmap的区别(结构不同,hashtable是锁整个对象和方法)
20.有哪些java的锁?实现类?cas是什么?aqs是什么?(乐观悲观,公平非公平,只说了ReentrantLock,面试官接着问还有呢?cas,乐观锁的实现,会造成aba问题,加版本号或者时间戳。aqs是锁框架)
21.线程池怎么使用,常用的参数?(使用ThreadPoolExcutor,核心线程数,最大线程数,时间,队列,线程工厂,拒绝策略)
22.假如有50个任务去执行,5个核心线程,10个最大线程数,10个任务队列,流程是怎么样的,状态是怎么样的?多余的任务是怎么用拒绝策略的(创建5个核心线程,10个放队列,队列满了,再创建10个非核心线程,剩余25个根据拒绝策略来决定,默认报异常,其余三种:要么忽略,要么放弃最早的线程,要么用该线程去执行)(后来才知道回答错了,10个最大线程数,5个核心+5个非核心,剩下的30个走拒绝策略)
面试官给我的评价:面试的都能答出来,这一点很不错,但了解的不深,虽然工作上用不到,但是面试就是这样造火箭的。面试不会差,但也不优秀,处于待定状态。
1.问的项目问题比较多,怎么设计功能的,数据库是怎么设计的
2.左连接,右连接,内连接的区别
3.mysql执行计划,有哪些看的
4.springmvc执行过程,从前端到后台,再返回前端的过程
5.权限验证,验权怎么做
6.数据库的锁(乐观锁,悲观锁,独占锁,共享锁)
7.select, update, delete对应哪些锁
8.java集合体系(list,set,map)
9.arraylist删除元素有哪些注意的地方
10.arraylist是线程安全的吗(不是,线程安全:vector,copyonwritearraylist)
11.什么时候用arraylist,linkedList(频繁增删用linkedList)
12.深拷贝和浅拷贝
13.值传递和引用传递
14.多线程,线程池
15.资源同步是怎么做的?
16.synchronize可以修饰静态类吗
17.lock和synchronize的区别?用的话,你会怎么选
18.平时怎么学习的(看教程,看博客)
19.自己的规划是什么?(规划学微服务,分布式等等)
20.技术方面的优势是什么
21.代码怎么优化,重构(单一职责,共用等等)
22.自己的网站是怎么进行性能优化的?(加cdn,加redis)
23.你有什么想问我的?你们那边用到的技术是什么?面试官:技术桟是封装框架,没有前端,用拖拉组件什么的,微服务是dubbo,数据库是oracle,侧重点是业务,技术次要。
最后面试官说:有四轮面试,这边面试完跟总监商量一下(剩下3轮都不是技术面)
1.spirngboot启动原理(内嵌tomcat…)
2.启动的注解(springbootapplication)
3.springboot核心配置
4.配置文件的方式(yml, properties)
5.springmvc的工作流程
6.springmvc的组件
7.@requestmapping的作用(拦截url)
8.spring常用的模块,核心
9.说一说ioc和aop
10.spring常用的注入方式
11.spring的bean有没有了解
12.spring事务的实现
13.spring的隔离
14.数据库的隔离级别(读未提交,读已提交,可重复读,串行化)
15.隔离级别的影响(脏读,不可重复读,幻读)
16.原子性,持久性(不可分割,保存到数据库)
17.char和varchar的区别(字节大小,’'和"")面试官继续问还有没有。。。
18.left join和right join的区别
19.sql你是怎么调优的
20.sql执行计划(explain)
21.sql的行锁和表锁,优势(锁一行和锁整个表)
22.乐观锁,悲观锁(版本号,时间戳)
23.mysql的引擎,区别(innodb支持外键,行锁,支持奔溃恢复,myisam支持全文索引)
24.select count(*) from table,数据是怎么执行的,会造成全表扫描吗(innodb,不支持全文索引,所以在innodb会造成全表扫描)
25.float和double内存占多少字节
26.在自增表,有6条数据,删了两条数据,再增加一条数据,这条数据的id是多少(innodb是7,myisam是5,结果说反了)
27.redis使用场景,和memcache的区别
28.redis的持久化(rdb和aof,全量,增量)
29.了解redis分布式,有多少个节点,以及一些命令
30.nginx应用场景(前后端分离,负载均衡)
31.负载均衡的策略(轮询,权重等等)
32.前后端是怎么交互的
33.正向代理和反向代理
34.swagger有了解吗(接口文档)
35.==和equals的区别
36.堆栈有了解吗
37.stringbuilder和stringbuffer的区别(线程安全,效率)
38.io流(reader和writer,inputstream和outputstream)
39.fileinputstream和bufferinputstream的区别
40.集合(list,set,map)
41.线程安全的集合有哪些(vector,copyonwritearraylist,hashtable, concurrenthashmap)
42.hashmap的实现过程(1.7头插,1.8尾插)
43.hashset和linkedhashset(底层hashmap,有序,底层linkedhashmap,无序)
44.深拷贝,浅拷贝
问的时间差不多40分钟了,因为还要工作,就打断面试了,结果晚上就来了第二轮面试
1.mysql查询,有很多关联的表,怎么优化(表加字段,适当冗余,少关联表,不要用*,in,null,or, %等等)
2.索引失效的情况(in,null,or, %等等)
3.常用的集合类(list,set,map及实现类)
4.线程安全的容器有哪些(vector,copyonwritearraylist,hashtable,concurrenthashmap)
5.concurrenthashmap是怎么保证线程安全的(1.7用分段锁,16个都上锁,1.8用cas+syn)
6.hashmap的数据结构(1.7数组+链表,多线程会形成一个环,cpu会飙升100%,1.8数组+链表+红黑树)
7.什么情况下会转成红黑树(key,hash,数组大于64,链表大于8,转成红黑树)
8.重写了equals,还需要重写hashcode方法吗(因为根据key,hash计算出来有可能会冲突,所以要重写hashcode)
9.链表是双向链表吗
10.redis的数据结构(string,set,sort set,list,hash,bitmap等等)
11.redis分布式锁
12.b+树了解吗(mysql索引)
13.缓存击穿(缓存失效,在缓存找不到,在数据库有数据)
14.解决办法(设置缓存失效时间随机,错开时间,或者给个标记)(其实是设置热点数据永远不过期或者加互斥锁等等)
15.threadlocal有了解吗(发音没听清,听成什么logo了,听了三遍没听出来,后面才反应他要说什么)
16.项目中遇到的困难(mrp功能)
17.服务器cpu上升到90以上的时候,还可以用多线程吗?
18.最近有研究什么新的技术吗?(在学习微服务)
19.微服务相关组件,一些没听过(说了一下这些是干嘛的)
20.zookeeper有了解吗(分布式)
21.内存泄露有哪些情况?
22.从专业角度+性格,评价自己
23.你希望的项目是什么样的?(技术桟,技术氛围)
24.linux常用命令(ls,cd,pwd,chmod,vi,whereis,find二进制文件)
面试官:到岗时间比较急,技术栈是springboot+dubbo,微服务集群,zookeeper+redis+mysql等等
面试评价:没什么大问题,希望快点入职
jvm,微服务和分布式等等的没有记录了,自己没接触过,听到了也忘记,没有及时写上去。还有一些面试,没有去记录了,整理和记录面试挺费时间的,上面的主要记录技术面试。有些终面,面了40分钟,问生活细节,有什么爱好,之前写的博客,还记得吗?xx篇,你还记得写了什么内容吗?你是哪里人,将来是不是还待在深圳?晕死,一直问,问了40多分钟,如果我不打断,可能会一个小时以上。像这样的流水账面试,就没有写到上面去了。
最后比较幸运,拿下几个offer,面试题还是得多刷题,避免答不出来,另外收到offer的机会才会多。
待的公司,比较安逸稳定,也算是个温室,业务比较复杂(ERP系统),项目架构比较简单,单体项目,去年说加缓存的一直没加,单表数据最多是上千,现在是260多张表。目前有20个客户,cpu飘升到百分之90,之后,服务器奔溃,好几次都这样。后来我们CTO的解决办法是把功能给禁掉(MRP运算),后来发现是报表问题,oom错误,换了报表工具。过了一段时间,加了内存,加服务器。(微服务,分布式,缓存,集群,消息队列都没用到,也学不到),一直做一些复杂的业务功能,写业务代码。还是早一点离开技术得不到提升的地方,虽然他一直给我洗脑,说会那么多技术有什么用,你业务不会,代码不会写,会再多技术也是等于零。但我心里一直否认,毕竟我是搞技术的,懂基本业务可以,讨论业务,需求可以交给项目经理什么的,最后安排我做什么就行了。除非走业务路线,走管理,懂技术懂业务。像我这种学五渣,不适合走业务。