2019年Java大厂面试(吐血超详细总结)

本文来自于慕课网手记:

Java大厂面试(吐血超详细总结)
作者:小码哥的freestyle
链接:

https://www.imooc.com/article/286545
来源:慕课网

面试清单

  • 平安产险

  • 飞猪

  • 上汽大通

  • 浩鲸科技

  • 杏仁医生

  • 兴盛优先

  • 御泥坊

  • 拓维信息

  • 陆金所

  • 蜜獾信息

  • 丰巢科技

  • SAP

  • 房多多

  • DellEMC

  • Amazon

  • 有赞

  • Ericsson

  • 步步高

  • 福米科技

平安产险

先通过邮件发了一份线上测评(EQ+IQ), 做完达到要求后才能有后续的面试机会,没有通过两年之内不能进平安任何一家公司。

一面

自我介绍

看我工作时间不长,问我为什么频繁跳槽(间接问离职原因)

关注过平安哪些架构?

我就说了军哥的pass平台

解释下什么是用户态和内核态?两者有什么区别?

内核态:当一个任务(进程)执行系统调用而陷入内核代码中执行时,我们就称进程处于内核运行态(或简称为内核态)。其他的都属于用户态

用户程序运行在用户态,操作系统运行在内核态(操作系统内核运行在内核态,而服务器运行在用户态)。用户态不能干扰内核态.所以CPU指令就有两种,特权指令和非特权指令.不同的状态对应不同的指令。特权指令:只能由操作系统内核部分使用,不允许用户直接使用的指令。
如:I/O指令、置终端屏蔽指令、清内存、建存储保护、设置时钟指令(这几种记好,属于内核态)。非特权指令:所有程序均可直接使用。

所以:

系统态(核心态、特态、管态):执行全部指令。

用户态(常态、目态):执行非特权指令。

用户态和内核态的理解和区别

用过Spring boot哪些版本?新版本相对于旧版本有哪些改变?

https://github.com/spring-projects/spring-boot/wiki

Spring Boot 2.x 与 1.x 的区别,以及如何做版本迁移

web.xml中DispatcherServlet的作用?

Spring MVC中的DispatcherServlet作用

DispatcherServlet过程详解

讲下web.xml中Filter类(过滤器)

web.xml中的配置,servlet,filter,listener的作用和原理

使用Spring boot以后,与之前系统的配置方式区别方面?(Spring boot 和 Spring MVC 使用和配置上的区别?)

SpringBoot - 注册Servlet、Filter和Listener(代码和注解两种方式)

spring boot与spring mvc的区别是什么?

好像还有个reactivity什么的,当时记不清了。

你们如果面试碰到了相关经典题目。欢迎补充!

二面

整理中

飞猪

首先这个面试机会是来自于内推,当然内推的人和我一面的面试官都是同一个人,所以 嘿嘿嘿 你懂得…

第一次面试(2019年3月13日)

自我介绍

介绍一下你这边最熟悉的项目?在开发过程中印象最深刻地方?

Springboot 2.0.0和Springboot 1.5.6的区别?

https://github.com/spring-projects/spring-boot/wiki

Spring Boot 2.x 与 1.x 的区别,以及如何做版本迁移

有没有看过Springboot的源码?(很尴尬,没有研究过)

https://github.com/spring-projects/spring-boot

Springboot中遇到的一些坑及解决方法?

Springboot与shiro整合遇到的坑

Spring Boot 从1.0 升级到 2.0 所踩的坑

有没有看过Spring的源码?(很尴尬,了解过)

https://github.com/spring/spring

你现在对Dubbo了解得怎么样?(作为这个项目的贡献者,没有深入阅读源码和实践真的是汗颜)

https://github.com/apache/incubator-dubbo

30 道 Dubbo 面试题及答案

JDK 1.9 的新特性?(我说:没有用过1.9,感觉1.9不是很稳定,只用过1.8)那说一下 1.8 有哪些新特性?

jdk8, jdk8u, jdk9, jdk10的侧重和区别是什么?

JDK 9新特性汇总

JDK1.8新特性(持续更新)

JDK有哪些实现代理方法?JDK动态代理和CGlib动态代理有什么区别?

深入理解静态代理与JDK动态代理

JDK动态代理与CGLib动态代理相关问题

介绍下OOM?开发过程中遇到过哪些OOM,怎样解决的?

OutOfMemoryError,当JVM因为没有足够的内存来为对象分配空间,并且垃圾回收器也已经没有空间可回收时,就会抛出这个error(注:非exception,因为这个问题已经严重到不足以被应用处理)。

因为OutOfMemoryError是可以catch的。catch之后吞掉的话程序还能试着继续运行。例如说以前见过的一个案例是:一个Java服务器端应用,有段代码没写对导致有一个线程在疯狂创建大数组对象——直到OOM。这个线程注册的uncaught exception handler捕获到了这个异常,记录了日志,然后就把这个异常吞掉了。这样还能继续正常跑下去是因为:只是一个创建很大的数组对象的请求失败了而已,而出错的那个方法由于异常处理已经被退出了,程序的其它部分并没有受影响。

JVM 发生 OOM 的 8 种原因、及解决办法

介绍下Java内存模型?

Java内存模型(JMM)总结

你这边还有什么问题?

第二次面试(2019年12月29日)

自我介绍

面试中自我介绍虽然很常见,我觉得很有必要根据不同公司,不同的JD来写几份不同的自我介绍,以备不时之需。

最新项目中主要负责哪一块?运用了哪些技术?项目整体架构是怎样的?

Java ClassLoader ? 双亲委派?

老大难的 Java ClassLoader 再不理解就老了

消息队列 RocketMQ 版消费失败如何重新消费消息?

集群消费方式

消费业务逻辑代码如果返回 Action.ReconsumerLater,或者 NULL,或者抛出异常,消息都会走重试流程,至多重试 16 次,如果重试 16 次后,仍然失败,则消息丢弃。可以通过调用 message.getReconsumeTimes() 方法来获取消息的重试次数。

广播消费方式

广播消费方式仍然能保证一条消息至少被消费一次,但消费失败后不做重试操作。

消息队列常见问题和解决方案

消息队列消费场景:A扣钱成功,调用B加钱接口失败。

  • 强一致性,分布式事务(难落地)

  • 最终一致性,主要是用“记录”和“补偿”的方式。在做所有的不确定的事情之前,先把事情记录下来,然后去做不确定的事情,结果可能是:成功、失败或是不确定,“不确定”(例如超时等)可以等价为失败。成功就可以把记录的东西清理掉了,对于失败和不确定,可以依靠定时任务等方式把所有失败的事情重新搞一遍,直到成功为止。

最后,系统在A扣钱成功的情况下,把要给B“通知”这件事记录在库里(为了保证最高的可靠性可以把通知B系统加钱和扣钱成功这两件事维护在一个本地事务里),通知成功则删除这条记录,通知失败或不确定则依靠定时任务补偿性地通知我们,直到我们把状态更新成正确的为止。

高并发之消息队列

分布式事务场景:商城一次支付过程。用户下单使用组合支付,即余额加红包支付。但是在调用红包系统扣减红包系统失败,如何解决?

引入 TCC 事务,将整个下单过程作为一个整体。引入后,由于余额系统扣减是失败,这个时候我们回滚订单系统与红包系统。由于余额系统的失败,我们需要撤销这次过程中所有更改,所以我们向订单系统发送撤销通知,向红包系统发出撤销通知。

聊聊分布式事务

数据库操作:左连接 ,右连接

left join (左连接):返回包括左表中的所有记录和右表中连接字段相等的记录。

right join (右连接):返回包括右表中的所有记录和左表中连接字段相等的记录。

左连接 ,右连接,内连接和全外连接的4者区别

算法题:有一栋100层高楼,从某一层开始扔下的玻璃球刚好摔坏,现有两个玻璃球,试用最简便的方法确定这个恰好摔坏玻璃球的那层。

第一个玻璃球用来找到摔坏的楼层范围,第二个玻璃球找到具体摔坏球的楼层。

假设一开始从第k层投,如果坏了,那么第二个球可以在剩下的k-1层一定能用k-1次确定哪层坏,再加上第k层的那次,所以总共k次。如果第k层没有坏,那么第一个球在第k层的基础上再加k-1层(注意不是k层,原因见后面),所以第二次从2k-1层投下,在k,k+1,k+2,……,2k-2,2k-1中则有k-2层,所以用k-2次才能找出,再加上原来的那两次,还是共用了k次(为了保持总共还是k次,所以上面只能加k-1层)。

依次类推,在第2k-1层基础上再加k-2层,在第3k-3层基础上再加k-3层,……,依次类推,一定能加到在第某层的基础上再加2层,最后再原来的基础上面还能再加1层,到目前为止,设为第n-1层,如果第n-1层坏了,那么就是第n-1层,如果没有坏,根据已知题说某一层能摔碎球,那么在第n-1层上面有且仅还有一层就是刚摔坏的层(此时不需要实际投,而是直接推理得出),这时用的次数还是k次(最不理想的结果),所以k次能测最多n层,由上面的解说,可知n-1=k+(k-1)+(k-2)+(k-3)+……+2+1=k(k+1)/2,得n=k(k+1)/2+1,由上面可知n=100(层),k次最多能推测k(k+1)/2+1(层),所以k(k+1)/2+1≥100,得k(k+1)≥198,且k的最小整数为14,所以最多14次就能找出题目中的那层。

补充:由上得知,第一次在14层投,第二次在第27层投,则依次为14 27 39 50 60 69 77 84 90 95 99。还能得出14次最多能测得到106楼,只不过题目中给了100楼,如果是107楼,那么就需要15次了。

用2个玻璃球找到从一100层的大楼的某一层落下刚好会摔碎,如何制定最优策略?

给你两个球,100层楼,每个球在一定高度扔下去会碎,怎么用最少的次数给判断是几层楼能把求摔碎?

平时是怎样学习新知识的?

你有平时写博客的习惯吗?

你这边还有什么问题?

我觉得我这次表现的不是太好,你有什么建议或者评价给我吗?

阿里招人级别的标准,现在是不是越来越难了?

上汽大通

一套J2EE+Oracle的笔试 大概有五六张纸 我只依稀记得几道题

现场面试

main方法中是否可以调用非静态方法

可以,一种方法将main方法写成静态方法,另一种将当前类实例化再调用它的非静态方法,例如:

public class Test {
private int a;
public int getnumber() {
setnumber(8);
return this.a;
}
public int setnumber (int a) {
return this.a=a;
}
public static void main(String args[]){

}
}

改为:

public class Test {
    private int a;
 
    public int getnumber() {
        setnumber(8);
        return this.a;
    }
 
    public int setnumber(int a) {
        return this.a = a;
    }
 
    public static void main(String args[]) {
        Test t = new Test();
//      t.setnumber(10);
        int a = t.getnumber();
        System.out.println(a);
    }
}

解释下AOP和IOC的工作机制?

AOP思想的实现一般都是基于代理模式 ,在JAVA中一般采用JDK动态代理模式,但是我们都知道,JDK动态代理模式只能代理接口而不能代理类。因此,Spring AOP 会这样子来进行切换,因为Spring AOP 同时支持 CGLIB、ASPECTJ、JDK动态代理。

Spring IOC的初始化过程:

XML ------> Resource ------> BeanDefinition ------> BeanFactory

如何理解Spring中的IOC和AOP

servlet的生命周期

javax.servlet.Servlet接口中的init()、service()和destroy()方法来表示,主要包括四个阶段:

  • 加载和实例化

  • 初始化

  • 请求处理

  • 服务终止

String、StringBuffer和StringBuilder三者区别?

JAVA中String与StringBuffer,StringBuilder的区别

StringBuffer 和 StringBuilder 的区别是什么?

怎么实现synchronized的可重入?

synchronized是可重入的,对同一个执行线程,它在获得了锁之后,在调用其他需要同样锁的代码时,可以直接调用。

可重入是通过记录锁的持有线程和持有数量来实现的,当调用synchronized保护的代码时,检查对象是否已被锁,如果是,再检查是否被当前线程锁定,如果是,增加持有数量,如果不是被当前线程锁定,才加入等待队列,当释放锁时,减少持有数量,当数量为0时才释放整个锁。

synchronized 关键字

RuntimeException和Exception的区别?

java基础学习(12)RuntimeException和Exception

wait()和sleep()的区别?

sleep( ) 和 wait( ) 的这 5 个区别,你知道几个?

有三个线程t1、t2、t3。确保三个线程t1执行完后t2执行,t2执行完成后t3执行?

用 Thread 类的 join 方法。

private static void threadJoinOneByOne() throws InterruptedException {
      Thread t1 = new Thread(ThreadExecutionQuestion::action, "t1");
      Thread t2 = new Thread(ThreadExecutionQuestion::action, "t2");
      Thread t3 = new Thread(ThreadExecutionQuestion::action, "t3");

      // start() 仅是通知线程启动
      t1.start();
      // join() 控制线程必须执行完成
      t1.join();

      t2.start();
      t2.join();

      t3.start();
      t3.join();
  }

  private static void action() {
      System.out.printf("线程[%s] 正在执行...\n", Thread.currentThread().getName());  // 2
  }
}

CountDownLatch也可以实现

调整优先级并不能保证控制线程执行顺序

&和&&的区别?

电路问题总结:

&:不管怎样,都会执行"&"符号左右两边的程序

&&:只有当符号"&&“左边程序为真(true)后,才会执行符号”&&"右边的程序。

运算规则:

&:只要左右两边有一个为false,则为false;只有全部都为true的时候,结果为true

&&:只要符号左边为false,则结果为false;当左边为true,同时右边也为true,则结果为true

sql语句selectgroup byorder bywhere先后顺序?

写的顺序:select … from… where… group by… having… order by…

执行顺序:from… where…group by… having… select … order by…

解释Java内存模型?

Java内存模型(JMM)总结

JDBC如何连接数据库?

JDBC【介绍JDBC、使用JDBC连接数据库、简单的工具类】

两位技术负责人+部长(周)简单聊了一下,自己的项目和经验,遇到过哪些问题?怎么解决的?怎么设计数据库模型?

浩鲸科技

一面

自我介绍

谈一下自己最熟悉的项目中的业务框架?

(登录+权限VIP服务绑定)

开发过程中后端如何提交给前端接口?

如何解决前后端token过期问题?

每隔一段时间在后端请求中都将token传送过去,获取新的token值,并返回前端放入cookies中并记录cookie的存储失控,达到更新cookie中token的效果;而长时间不做操作的话我们就可以让他的token失效退出系统了。

如何解决前后端token过期问题

如何实现在登录中高可用?什么是高可用?

用户信息存redis;加节点,加机器,多部署实例。

什么是高可用

你实际java开发多长时间?

当问我这个问题的时候,我就知道前面答得并不是很好,所以面试官后面问的都是基础题。

抽象类和接口有什么区别?

接口和抽象类有什么区别?

用过哪些集合?list和set的区别?

深入理解Java中的List、Set与Map集合

用过哪些设计模式?

如何在代码中应用设计模式

你这边还有什么问题?

因为这个项目是和杭州阿里系的大佬们一起开发盒马鲜生这款产品,所以着重问了下开发产品情况和团队架构。

你现在的薪资和期望薪资?

照实际的说,大厂一般都会查银行流水。

二面

整理中

杏仁医生

一面

自我介绍

mysql 常用存储引擎有哪些?分别有什么特点和区别?

MySQL常用存储引擎

谈一谈MySQL的四种事务隔离级别,有哪些区别?

MySQL的四种事务隔离级别

说一下非公平锁?平时用到的是非公平锁多一点还是公平锁多一点?

非公平锁的优点是可以减少唤起线程的开销,整体的吞吐效率高,因为线程有几率不阻塞直接获得锁,CPU不必唤醒所有线程。缺点是处于等待队列中的线程可能会饿死,或者等很久才会获得锁。

谈一下volatile关键字你是怎么理解的?能否保证原子性?(比较synchronized关键字)

volatile关键字是线程同步的轻量级实现,所以volatile性能肯定比synchronized关键字要好。但是volatile关键字只能用于变量,而synchronized关键字可以修饰方法以及代码块。synchronized关键字在JavaSE1.6之后进行了优化,主要包括为了减少获得锁和释放锁带来的性能消耗而引入的偏向锁和轻量级锁以及其它各种优化,执行效率有了显著提升,实际开发中使 用 synchronized 关键字的场景还是更多一些。

多线程访问volatile关键字不会发生阻塞,而synchronized关键字可能会发生阻塞。

volatile关键字能保证数据的可见性,但不能保证数据的原子性。synchronized关键字两者都能保证。

volatile关键字主要用于解决变量在多个线程之间的可见性,而 synchronized关键字解决的是多个线程之间访问资源的同步性。

谈一下乐观锁和悲观锁?

面试必备之乐观锁与悲观锁

面试官:什么是乐观锁请举例 程序员:瑟瑟发抖 不懂啊

谈一下守护线程?用到过哪种?

java 多线程 守护线程

ArrayList和LinkedList的区别?

Java中ArrayList和LinkedList区别

简单介绍下java中常见的引用类型

java基本类型与引用类型

兴盛优先

说下面试前奏,我和这个公司互相鸽了一次,第一次我是因为那次在地铁里,信号不好怕影响面试效果,就提前说明了;结果第二次本来约的是晚上8:00,结果9:15分打电话过来面试,fuck,我还在洗衣服。面试官说只要20分钟,如果不方便可以下次约,好像这个面试官是已经下班了,在家里跟我打得电话,我觉得都不容易,还是同意面了。

说来也奇怪,竟然没让我自我介绍,直接上来就跟我聊参与的开源项目 Dubbo,问我为这个项目贡献了哪一块?我轻描淡写的描述了主要负责 Dubbo的哪些生态,和如何管理控制版本的发布等等。因为我主要负责官网的迭代和维护,而Apache项目之间的沟通都是英文交流,老外喜欢用邮件列表的形式来讨论,不会像国内的开源项目,任务认领的方式是在社交软件上进行沟通,老外根本就不用。顺便问了下我英语怎么样?我讲完后,顺便介绍了下我自己。接下来正式进入面试环节。

一面

谈一谈 Dubbo 序列化协议

Dubbo 支持 Hessian、Java 二进制序列化、json、SOAP 文本序列化多种序列化协议。但是 Hessian 是其默认的序列化协议。

谈一下 Dubbo 的整体架构中的网络传输层(Transport)?

抽象 mina 和 netty 为统一接口,以 Message 为中心,扩展接口为Channel、Transporter、Client、Server和Codec

30 道 Dubbo 面试题及答案

说一下你最熟悉的项目中,遇到的印象最深刻的问题?是怎么解决的?

Springboot与shiro整合遇到的坑

说一下在HashMap中遇到的hash冲突是如何解决的?

HashMap?面试?我是谁?我在哪

原理:HashMap基于哈希表实现的,通过put和get方法存储和获取对象。当调用put方法时,通过键对象的hashCode找到在数组中的位置来存储值对象。当获取对象时的时候,先通过键对象的hashCode找到数组中的位置,然后通过键对象的equals()方法找到正确的值对象。

HashMap使用LinkedList来解决碰撞冲突,当两个对象的hashCode相等时它们在数组的位置相同就会发生碰撞冲突,这个时候对象将会存储在LinkedList的下一个节点中。获取对象的时候通过键对象的equals方法遍历LinkedList直到找到正确的值对象。

谈一下List接口有哪些特性?

深入理解Java中的List、Set与Map集合

说一下ArrayList和LinkedList区别?

Java中ArrayList和LinkedList区别

foreach循环里进行元素的remove/add操作,这样合理吗?为什么?

不合理

为什么阿里巴巴禁止在 foreach 循环里进行元素的 remove/add 操作

当有线程 T1、T2 以及 T3,如何实现 T1 -> T2 -> T3 的执行顺序?以上问题请至少提供另外一种实现?

用 Thread 类的 join 方法。

private static void threadJoinOneByOne() throws InterruptedException {
      Thread t1 = new Thread(ThreadExecutionQuestion::action, "t1");
      Thread t2 = new Thread(ThreadExecutionQuestion::action, "t2");
      Thread t3 = new Thread(ThreadExecutionQuestion::action, "t3");

      // start() 仅是通知线程启动
      t1.start();
      // join() 控制线程必须执行完成
      t1.join();

      t2.start();
      t2.join();

      t3.start();
      t3.join();
  }

  private static void action() {
      System.out.printf("线程[%s] 正在执行...\n", Thread.currentThread().getName());  // 2
  }
}

CountDownLatch也可以实现;

调整优先级并不能保证优先级高的线程先执行。

好像还有一个问题?是一个专有技术名词的解释?我真的没听过…

御泥坊

这个也是一个朋友内推,工资要砍半,细节我就不说了,直接上干货。

说一下你最熟悉的项目中,遇到的印象最深刻的问题?是怎么解决的?

Springboot与shiro整合遇到的坑

说一下TCP/IP 协议

HTTP协议—— 简单认识TCP/IP协议

如何让Redis与Mysql数据保持同步?

如何保持mysql和redis中数据的一致性?

redis与Mysql的数据一致性

如何查询Hashmap里面的元素?(增删改查)

【面向对象版】HashMap(增删改查)

说一下Hashmap 扩容机制?第一次扩容到达的阈值是多少?

JDK 1.7: 深入理解HashMap的扩容机制

JDK 1.8: jdk1.8 HashMap工作原理和扩容机制(源码解析)

默认大小为16,负载因子0.75,阈值12

拓维信息

这个是Boss直聘找的,本来是另一个HR先跟我聊得,后面他出差了,来了个小姐姐找我。

一面

说一下Spring boot(工作机制,和spring mvc对比优缺点)

这10道springboot常见面试题你需要了解下

说一下Spring MVC框架

Spring MVC框架

工作中有没有遇到过Mysql优化,请谈一谈

巧用这19条MySQL优化,效率至少提高3倍

最全 MySQL 优化方法,从此优化不再难

Mysql一般什么情况查询容易出现索引失效?怎么解决?

关联查询

Mysql之索引失效

MySQL避免索引失效

说一下在工作项目中如何运用Redis的?

Redis

工作中使用Java多态多吗?请简单说一下

浅谈java多态

浅谈Java的多态

工作中用过哪些接口?其中List有哪些类?谈一下它们的区别?

工作3年出去面试Java,被鄙视spring的接口有哪些都不清楚

深入理解Java中的List、Set与Map集合

有使用过Spring Cloud吗?有了解过微服务吗?

对前端技术有了解吗?

你这边有什么问题?

陆金所

一面

看我工作时间不长,问我为什么频繁跳槽(间接问离职原因)

说一下Java类加载机制?

Java类加载机制

说一下GC中 G1 G2 的算法

G1 收集器原理理解与分析

为啥你们公司在使用Mysql,还要使用MongDB?

我为什么放弃MySQL?选择了MongoDB

说一下 B+树 的理解?

平衡二叉树、B树、B+树、B*树 理解其中一种你就都明白了

你对索引有了解吗?说一下A =‘a’,B=‘b’, AB=‘ab’?(这个题说实话没听清面试官的意思,应该是问的是否会造成索引失效)。

蜜獾信息

一面

说一下最近做过的项目

你使用过哪些JDK版本?

用过哪些集合包?

ArrayList、LinkedList、Vector、Stack、HashSet、TreeSet、HashMap、TreeMap

深入理解Java中的List、Set与Map集合

说一下ArrayList、LinkedList、HashMap 底层数据结构

Arraylist 与 LinkedList 区别?

一篇文章搞定ArrayList和LinkedList所有面试问题

HashMap底层实现原理(上)

HashMap底层实现原理(下)

Arraylist 是有序还是无序?

有序

有哪些方式可以实现多线程?

Java多线程实现的四种方式

用过哪些并发包(我反问面试官是不是JUC,为何他说不是?)

java并发包、线程池、锁

说一下sleep( ) 和 wait( )的区别?

sleep( ) 和 wait( ) 的这 5 个区别,你知道几个?

开发过程中遇到过哪些异常?Exception 与 error的区别?说一下error层次结构?

Java异常处理

用过哪些数据库?说一下Mysql 四种事务隔离级别?哪种级别最高?为什么?

真正理解Mysql的四种事务隔离级别

用过索引吧?在使用索引需要注意什么?(如何避免索引失效?)

如何理解并正确使用MySql索引

Mysql索引简明教程

Mysql之索引失效

MySQL避免索引失效

说一下Spring MVC框架

Spring MVC框架

http 和 https 的区别?

http就是我们说的超文本传输协议,这个协议它是用一种明文的方式发送我们的内容,没有任何的加密。比如说我们访问一个网站,我们可能需要在这个网站输入密码,登录账号之类的操作,那我们的账号和密码就会发送到网站的服务器上面。但要是有人在中途截取了我们的信息,那我们的一些比较重要的信息可能就暴露了,所以为了解决http在传输过程中不加密的问题,之后就增加了一个SSL协议,这个协议简单说就是一个提供数据安全和完整性的协议,也就是负责网络连接的加密。

比如我们访问一个https的网站,那我们的电脑就会先和服务器建立一个安全的连接通道,然后服务器会先发送一份网站的证书信息到我们电脑,就相当于是告诉我们电脑,你访问的服务器没有问题。确认了信息之后,我们服务器就会生成一个加锁的箱子,但是这把锁有两把不一样的钥匙,一把是给我们电脑的,另一把是服务器自己的。然后服务器就会把没有上锁的箱子和钥匙发给我们电脑,我们把信息放在箱子里面之后,用钥匙锁上,然后发给服务器,服务器再用自己的钥匙打开箱子,来保证信息的安全。在这个过程中,即使箱子被别人拦截了,因为没有服务器的钥匙,以目前的技术来讲,还是很难打开箱子的。所以现在的一些大的网站,尤其是购物网站、或者是需要我们登录的网站,基本上都是https的。

http 和 https 有何区别?如何灵活使用?

一般数据都是以什么形式传给前端?

json格式

前后端数据交互之前端传值到后台

你这边还有什么问题?

丰巢科技

自我介绍

看到我说的和简历上的没差别,就没让我继续说了

你平时是怎么学习技术的?

有中间件开发经验吗?

如何搭建nacos/dubbo平台?

说一下Spring MVC框架

Spring MVC框架

Mybatis是如何将sql执行结果封装为目标对象并返回的?都有哪些映射形式?

第一种是使用标签,逐一定义列名和对象属性名之间的映射关系。第二种是使用sql列的别名功能,将列别名书写为对象属性名,比如T_NAME AS NAME,对象属性名一般是name,小写,但是列名不区分大小写,Mybatis会忽略列名大小写,智能找到与之对应对象属性名,你甚至可以写成T_NAME AS NaMe,Mybatis一样可以正常工作。
有了列名与属性名的映射关系后,Mybatis通过反射创建对象,同时使用反射给对象的属性逐一赋值并返回,那些找不到映射关系的属性,是无法完成赋值的。

十道常见的mybatis面试题

谈一谈公平锁和非公平锁?

最全Java锁详解:独享锁/共享锁+公平锁/非公平锁+乐观锁/悲观锁

两程序员玩“锁”,一人抢救无效身亡

简单聊下线程池?

线程池你真不来了解一下吗?

当面试官问线程池时,你应该知道些什么?

简单说一下Java内存模型(JMM)

Java内存模型(JMM)总结

工作中有没有Mysql优化的经验,请谈一谈

巧用这19条MySQL优化,效率至少提高3倍

最全 MySQL 优化方法,从此优化不再难

谈一下索引数据结构

数据库索引数据结构总结

简述 B+Tree

二叉树学习笔记之B树、B+树、B*树

谈一谈单链表和双链表的区别?

单链表:单链表只有一个指向下一节点的指针,也就是只能next。

双链表:双链表除了有一个指向下一节点的指针外,还有一个指向前一结点的指针,可以通过prev快速找到前一结点。一般我们都构造双向循环链表。

数据结构与算法-链表(上)

谈谈 synchronized 和 ReentrantLock 的区别

  • 两者都是可重入锁

  • synchronized 依赖于 JVM 而 ReentrantLock 依赖于 API

  • ReentrantLock 比 synchronized 增加了一些高级功能

相比synchronized,ReentrantLock增加了一些高级功能。主要来说主要有三点:①等待可中断;②可实现公平锁;③可实现选择性通知(锁可以绑定多个条件)

  • 两者的性能已经相差无几

谈谈 synchronized 和 ReentrantLock 的区别

思爱普

一面

String 和 StringBuilder 有何异同?

JAVA中String与StringBuffer,StringBuilder的区别

开发完后一般用什么测试工具测试?还是有人测试?

说说Java单元测试

JAVA 程序员需要用到 10 个测试框架和库

比较 checked exception 与 unchecked exception

Java异常:选择Checked Exception还是Unchecked Exception?

ClassNotFoundException 和 NoClassDefFoundErr区别?

ClassNotFoundException和NoClassDefFoundError的区别

谈一下 Threadlocal 和 ThreadLocalMap

深度揭秘ThreadLocal

ThreadLocal-面试必问深度解析

说一下 Mysql 中的 JOIN

图解 SQL 里的各种 JOIN

说一下 Mysql 中的事物隔离级别

MySQL的四种事务隔离级别

互联网项目中mysql应该选什么事务隔离级别

MongDB 中有哪些事物隔离级别?

MongoDB是如何实现事务的ACID?

如何保持 Mysql 和 redis中数据的一致性?

如何保持mysql和redis中数据的一致性?

说一下 redis 运用场景

Redis常见的应用场景解析

Mysql 有哪些优化方式?

巧用这19条MySQL优化,效率至少提高3倍

最全 MySQL 优化方法,从此优化不再难

Mysql中除了主键约束(primary key),还有哪些约束?

MySQL——约束(constraint)详解

请用英文介绍“温尔宝贝”项目?

wener baby app

The project is for continuous monitoring of user’s body temperature, real-time temperature, prompt the user and through the cyclical temperature data analysis of the user’s health.Using Springboot + mybatis architecture, mybatis - plus to simplify the development of the dao layer, and extract the universal service;Swagger document automatically generated interface, convenient interface test;Gradle management jar package, solve the jars conflict;Use redis for middle pressure to reduce database cache.

wener baby pad

The project on the basis of previous app, joint development with offline clinics and hospitals, and VIP card binding through mobile phones, on the pad for continuous monitoring of the user’s temperature display.Springboot + mongo framework, using the swagger automatically generated interface documents, convenient interface test;Taiwan before and after data interaction using the vue to simplify the dom manipulation;Neginx reverse proxy server, the data flow, split into multiple servers to improve the whole performance of the server system.

在Win系统中如何运行.sh文件?

win10下安装bash+运行.sh文件

房多多

自我介绍

说一下项目中登录模块业务

在登录模块中,主要负责注册、登录功能。在注册模块中,我们使用hibernate-validator依赖完成后台POJO的校验,可以防止用户跳过前端的js校验。在登录模块中,通过Controller,Service和Dao三层架构查询用户在数据库中是否存在信息,如果存在,则通过当前时间戳及用户id生成一个token,将token存入的redis中,然后把toekn存入到cookie中,发送给前端。

在多节点登录的前提下,如何防止同一账号,同时在多个不同设备登录

WEB系统防止同一账号,同时在多个不同设备登录

为什么要用redis存储token

1、token具有时效性,redis处理有优势。

2、在API领域,由于请求数比较多,redis也有优势。

3、登录信息一般不需要长效储存,所以可以减少DB的压力,直接用redis。

还有其他的看项目情形来定。

谈一下垃圾回收(GC 算法)

浅析JAVA的垃圾回收机制(GC)

说一下分布式锁

分布式锁看这篇就够了

说一下分布式事物以及应用场景

分布式事务?No, 最终一致性

工作中有用到过幂等吗?简单说一下

分布式高并发系统如何保证对外接口的幂等性?

什么是分布式系统中的幂等性

你这边还有什么问题?

戴尔易安信

解释下 final 关键字

final,static,this,super 关键字总结

Volatile 和 Synchronized 的区别?

volatile和synchronized的区别

如何设计 RESTful API?说一下幂等性?HTTP常用方法接触过哪些?分别是干什么的?

RESTful API最佳实践

如何更好的设计RESTful API

说一下用过哪些排序算法?

九种排序算法的可视化及比较

Mysql事务的基本要素(ACID)?一致性的业务场景?数据库中如何做到一致性?事务隔离级别?用例子说明不可重复读(read-committed)

MySQL的四种事务隔离级别

进程和线程的区别?

简述线程、程序、进程的基本概念。以及他们之间关系是什么?

图解进程和线程的关

接触过哪些数据库索引数据结构?什么是 B+Tree?

数据库索引数据结构总结

简单说一下数据库中的索引?

通俗易懂 索引、单列索引、复合索引、主键、唯一索引、聚簇索引、非聚簇索引、唯一聚簇索引 的区别与联系

说一下你工作中遇到哪些内存泄露

面试题:什么是内存泄漏?内存溢出?

谈一下垃圾回收机制(GC)?垃圾回收是回收的什么?

垃圾回收(Garbage Collection)是Java虚拟机(JVM)垃圾回收器提供的一种用于在空闲时间不定时回收无任何对象引用的对象占据的内存空间的一种机制。

注意:垃圾回收回收的是无任何引用的对象占据的内存空间而不是对象本身。换言之,垃圾回收只会负责释放那些对象占有的内存。对象是个抽象的词,包括引用和其占据的内存空间。当对象没有任何引用时其占据的内存空间随即被收回备用,此时对象也就被销毁。但不能说是回收对象,可以理解为一种文字游戏。

浅析JAVA的垃圾回收机制

如何实现多线程中的同步?

java中实现线程同步的7种方法

说一下线程同步中的读写锁?

Java 种15种锁的介绍:公平锁,可重入锁,独享锁,互斥锁,乐观锁,分段锁,自旋锁等

java中的读写锁

用英语介绍你最熟悉的项目?

wener baby (pad)

The project on the basis of previous app, joint development with offline clinics and hospitals, and VIP card binding through mobile phones, on the pad for continuous monitoring of the user’s temperature display.Springboot + mongo framework, using the swagger document automatically generated interface, convenient interface test;Taiwan before and after data interaction using the vue to simplify the dom manipulation;Neginx reverse proxy server, the data flow split into multiple server implementation, improve the performance of the entire server system.

你这边还有什么问题?

亚马逊

简历筛选测试

Test3 :

Note: if you cannot finish the test, you may still get the chance to next step of the hiring process if some shinning points were identified from your work: if you finish the work, you may still fail because your outcome did not meet the hiring bar.
Background: we want to build a solution to hire the right people quickly. The development work of this solution is part of the solution. As a candidate, please contribute your idea and finish the assignment.
Common requirements:

  1. Use Java as the main development language unless there is a solid reason for other choice.

  2. Provide test evidence (like the snapshot of the output of your solution) to easy the reviewer.

  3. The UT coverage must > 80% if not 100%.

  4. Please try to leverage the existing functionality of this project although it’s always fine to refactor them.

Test Description: for any key words, please get the 1st non-AD search result from baidu.com.

Definition of done:

  1. Define a mechanism for the user to provide the key words.

  2. The result will be shown on a web page (you may define the URL) of this project.


为了考核众多面试者的技术能力,请review一下该面试者的code:https://github.com/yingjil/JPHire/pull/6/commits/7b12ee650a15375a0b444f4374d0923e398bd02f 。他的任务是在Test3中描述的。对你的要求是用最高标准找到代码缺陷并提出修改意见。如果接受任务,请告知估计完成时间。

备注: 这个练习只是简历预审核的一步。完成任务不代表肯定能获得面试机会(HR依然可能拒绝简历)。拒绝参加本任务也不会留下任何不良记录。


个人理解

一、任务需求实现角度

1、需要定义一种提供用户输入搜索关键字的机制。我的理解是应该有一个简单的web页面,提供一个输入框,一个搜索按钮。而代码里这部分是缺失的。

2、搜索的结果需要展示在web页面中。这个也没看到对应的页面代码。

3、单元测试覆盖率要达到80%以上代码里测试用例过于简单,覆盖率远远低于80%。

二、代码实现角度

1、baidu.com 网站的页面元素规则是可变的,建议“第一个非广告搜索结果”的匹配规则设计成可配置,而不是写死在代码里。

2、WebPageUtil类的职责建议设计成通用工具类,而不是耦合具体业务代码。

3、考虑到扩展性,KeyWordSearchService应设计成接口,以支持不同搜索网站的各自实现。

有赞

hashmap 与 hashtable源码

hashmap 在 jdk 1.7 和 jdk 1.8 中的区别

线程池,线程参数的含义

生产设置线程数的依据是什么?

java.io.writer 有什么方法

hashcode equals 重写一个会有什么情况

sleep 加锁会释放吗?

缓存击穿,雪崩

1.缓存过期导致的击穿,如果只是单条,对系统没有影响;如果同时一大批过期,效果就相当于雪崩,压力都到了数据库,扛不住。解决办法:使得各个数据的过期时间尽量均匀,比如可以加随机数。使得数据库压力均匀。

2.缓存没命中导致的穿透,同样的问题。这个就需要尽量以缓存为准,即要么通过先返回空,再异步加载数据,要么就是用一个去重机制(bitmap 效果明显比 boomfilter 好)。还有一个方法就是,如果数据库里没有,也放一个key:null到缓存,加过期时间。

3.雪崩主要是靠高可用处理,分片、多实例、持久化,不要被清空了,宕机或重启,预热可以比较平稳,比如逐步加载数据。

如何保证幂等性,一般在什么环节处理?

说说你了解的分布式

爱立信

英语自我介绍

hello, everone! my name is Jiele Cao, 25 years old, from hunan, graduated from hunan university of technology, electronic information engineering in Shanghai has been working for three years after graduation, respectively in two Internet biological medical company involved in the backend development of four projects.First company Shanghai with biological technology co., LTD., work for more than a year, is mainly responsible for the company’s internal document management systems and WeChat public projects; wener recently, the Shanghai information technology co., LTD. Participated in two projects of a project which is Internet medical clinics online platform, the company is a company to do temperature detection, in the early stage of the project (wener baby), on the basis of the development on special pad, with modular service operations in the form of the project mainly includes frontend and backend, such as user, login, search module.

说一下 jdk 1.8 有哪些新特性?

jdk8, jdk8u, jdk9, jdk10的侧重和区别是什么?

JDK 9新特性汇总

JDK1.8新特性(持续更新)

线程安全?用过哪些线程安全的类?

Java集合中那些类是线程安全的

线程池?ThreadPoolExecutor 类用过哪些方法?

Java多线程-线程池ThreadPoolExecutor构造方法和规则

用过哪些JVM诊断工具?

【总结】性能调优:JVM内存诊断工具

JVM监控及诊断工具

遇到内存溢出怎么解决?

OutOfMemoryError,当JVM因为没有足够的内存来为对象分配空间,并且垃圾回收器也已经没有空间可回收时,就会抛出这个error(注:非exception,因为这个问题已经严重到不足以被应用处理)。

因为OutOfMemoryError是可以catch的。catch之后吞掉的话程序还能试着继续运行。例如说以前见过的一个案例是:一个Java服务器端应用,有段代码没写对导致有一个线程在疯狂创建大数组对象——直到OOM。这个线程注册的uncaught exception handler捕获到了这个异常,记录了日志,然后就把这个异常吞掉了。这样还能继续正常跑下去是因为:只是一个创建很大的数组对象的请求失败了而已,而出错的那个方法由于异常处理已经被退出了,程序的其它部分并没有受影响。

JVM 发生 OOM 的 8 种原因、及解决办法

JVM内存结构

JVM内存结构

用过哪些liunx系统的命令?如何用命令查找带有Java内容的文件?

Linux常用命令大全

Windows CMD中查找文件和文件内容

grep -r "{关键字}" {路径}

eg: grep -r "test" /data/reports

linux中如何用命令查看java进程?

ps -ef|grep java

用过Oracle吗?MySQL 如何调优?MySQL 如何避免索引失效?

MySQL 性能调优的10个方法

索引优化:索引失效(应避免)

步步高

一面

自我介绍

温尔宝贝 pad这个项目承担什么样的角色?

MySQL 组合索引

mysql 什么时候用单列索引?什么使用用联合索引?

MySQL 和 MongoDB 的区别?

MySQL与MongoDB的区别

MySQL 如何避免索引失效?

索引优化:索引失效(应避免)

假如线上项目出现问题,如何解决?

如何应对线上故障

用过哪些liunx系统的命令?查看日志命令?

Linux 命令大全

Linux查看日志常用命令

遇到异常怎么处理?

Java异常处理

Object类及其常用方法

Object类及其常用方法简介

java Object类及其常用方法

String、StringBuffer与StringBuilder的区别

String,StringBuffer与StringBuilder的区别??

"equals"和"=="的区别

equals和==的区别小结

ArrayList和LinkedList的区别?

LinkedList实现了List接口,允许null元素。此外LinkedList提供额外的get,remove,insert方法在LinkedList的首部或尾部。这些操作使LinkedList可被用作堆栈(stack),队列(queue)或双向队列(deque)。

注意LinkedList没有同步方法。如果多个线程同时访问一个List,则必须自己实现访问同步。一种解决方法是在创建List时构造一个同步的List:

List list = Collections.synchronizedList(new LinkedList(…));

特点:寻址困难,插入和删除容易。

ArrayList实现了可变大小的数组。它允许所有元素,包括null。ArrayList没有同步。

size,isEmpty,get,set方法运行时间为常数。但是add方法开销为分摊的常数,添加n个元素需要O(n)的时间。其他的方法运行时间为线性。

每个ArrayList实例都有一个容量(Capacity),即用于存储元素的数组的大小。这个容量可随着不断添加新元素而自动增加,但是增长算法并没有定义。当需要插入大量元素时,在插入前可以调用ensureCapacity方法来增加ArrayList的容量以提高插入效率。

和LinkedList一样,ArrayList也是非同步的(unsynchronized)。

特点是:寻址容易,插入和删除困难;

String str = new String(“abc”); 创建了几个对象

面试题之String str = new String(“abc”); 创建了几个对象

HashMap和Hashtable的区别

Hashtable继承Map接口,实现一个key-value映射的哈希表。任何非空(non-null)的对象都可作为key或者value。添加数据使用put(key,value),取出数据使用get(key),这两个基本操作的时间开销为常数。

Hashtable 通过initial capacity和load factor两个参数调整性能。通常缺省的load factor 0.75较好地实现了时间和空间的均衡。增大load factor可以节省空间但相应的查找时间将增大,这会影响像get和put这样的操作。

作为key的对象将通过计算其散列函数来确定与之对应的value的位置,因此任何作为key的对象都必须实现hashCode和equals方法。

Hashtable是同步的。

HashMap和Hashtable类似,不同之处在于HashMap是非同步的,并且允许null,即null value和null key。其迭代子操作时间开销和HashMap 的容量成比例,因此,不要将HashMap的初始化容量设得过高,或者load factor过低。

有哪些方法创建线程?

仅仅只有new thread这种方法创建线程

public class ThreadCreationQuestion {

    public static void main(String[] args) {
        // main 线程 -> 子线程
        Thread thread = new Thread(() -> {
        }, "子线程-1");

    }

    /**
     * 不鼓励自定义(扩展) Thread
     */
    private static class MyThread extends Thread {

        /**
         * 多态的方式,覆盖父类实现
         */
        @Override
        public void run(){
            super.run();
        }
    }

}

与运行线程方法区分:
java.lang.Runnable()java.lang.Thread类

线程池的优点?如何创建一个线程池?

1)避免线程的创建和销毁带来的性能开销。

2)避免大量的线程间因互相抢占系统资源导致的阻塞现象。

3}能够对线程进行简单的管理并提供定时执行、间隔执行等功能。

ExecutorService pool = Executors.newCachedThreadPool(); //可根据需要创建新线程的线程池
ExecutorService pool = Executors.newSingleThreadExecutor(); //创建是一个单线程池
ExecutorService pool = Executors.newFixedThreadPool();//创建固定大小的线程池
ExecutorService pool = Executors.newScheduledThreadPool();//创建一个大小无限的线程池

线程、多线程与线程池总结

sleep() 和 wait() 的区别

sleep() 和 wait() 的区别

SpringMVC 工作原理

客户端发送请求-> 前端控制器 DispatcherServlet 接受客户端请求 -> 找到处理器映射 HandlerMapping 解析请求对应的 Handler-> HandlerAdapter 会根据 Handler 来调用真正的处理器开处理请求,并处理相应的业务逻辑 -> 处理器返回一个模型视图 ModelAndView -> 视图解析器进行解析 -> 返回一个视图对象->前端控制器 DispatcherServlet 渲染数据(Moder)->将得到视图对象返回给用户

Spring 的理解

怎么回答面试官:你对Spring的理解?

分布式事务原理

分布式事务:分布式事务原理概述

如何设计接口?如何考虑接口安全性?

如何设计出一些优雅的API接口呢?

如何设计好的RESTful API之安全性

福米科技

虽然推迟了半个小时面试,但是这个面试官很耐心,等我答完后,把他的观点阐述,面试就应该这样,相互学习才是面试的最高境界。

自我介绍

乐观锁和悲观锁

乐观锁和悲观锁的区别

mysql出现索引失效情况

  • 如果条件中有or,即使其中有条件带索引也不会使用(这也是为什么尽量少用or的原因)。要想使用or,又想让索引生效,只能将or条件中的每个列都加上索引。

  • 对于多列索引,不是使用的第一部分,则不会使用索引。

  • like 查询以 % 开头。

  • 如果列类型是字符串,那一定要在条件中将数据使用引号引用起来,否则不使用索引。

  • 如果mysql估计使用全表扫描要比使用索引快,则不使用索引。

解释下“字符串不加单引号”是如何造成索引失效

SELECT * from staffs where name='2000';
SELECT * from staffs where name=2000;

这两条语句都会查询出正确结果,但第二条没有用到索引。因为mysql会在底层对其进行隐式的类型转换。

查询一张表中是否有重复数据?场景:一张表中有 id 和 name 两个字段,查询出 name 重复的所有数据

sql 查出一张表中重复的所有记录数据

多线程

线程、多线程与线程池总结

如何创建的一个线程池?(非调用接口)

public ThreadPoolExecutor(int corePoolSize,
                          int maximumPoolSize,
                          long keepAliveTime,
                          TimeUnit unit,
                          BlockingQueue workQueue,
                          ThreadFactory threadFactory) {
    this(corePoolSize, maximumPoolSize, keepAliveTime, unit, workQueue, 
        threadFactory, defaultHandler);
}

1)corePoolSize:线程池的核心线程数,一般情况下不管有没有任务都会一直在线程池中一直存活,只有在 ThreadPoolExecutor 中的方法 allowCoreThreadTimeOut(boolean value) 设置为 true 时,闲置的核心线程会存在超时机制,如果在指定时间没有新任务来时,核心线程也会被终止,而这个时间间隔由第3个属性 keepAliveTime 指定。

2)maximumPoolSize:线程池所能容纳的最大线程数,当活动的线程数达到这个值后,后续的新任务将会被阻塞。

3)keepAliveTime:控制线程闲置时的超时时长,超过则终止该线程。一般情况下用于非核心线程,只有在 ThreadPoolExecutor 中的方法 allowCoreThreadTimeOut(boolean value) 设置为 true时,也作用于核心线程。

4)unit:用于指定 keepAliveTime 参数的时间单位,TimeUnit 是个 enum 枚举类型,常用的有:TimeUnit.HOURS(小时)、TimeUnit.MINUTES(分钟)、TimeUnit.SECONDS(秒) 和 TimeUnit.MILLISECONDS(毫秒)等。

5)workQueue:线程池的任务队列,通过线程池的 execute(Runnable command) 方法会将任务 Runnable 存储在队列中。

6)threadFactory:线程工厂,它是一个接口,用来为线程池创建新线程的。

多线程阻塞?

JAVA多线程阻塞

集群分布式事务原理

分布式事务:分布式事务原理概述

并发控制锁策略什么情况下失效 / 为什么要使用分布式锁?

为了保证一个方法或属性在高并发情况下的同一时间只能被同一个线程执行,在传统单体应用单机部署的情况下,可以使用并发处理相关的功能进行互斥控制。但是,随着业务发展的需要,原单体单机部署的系统被演化成分布式集群系统后,由于分布式系统多线程、多进程并且分布在不同机器上,这将使原单机部署情况下的并发控制锁策略失效,单纯的应用并不能提供分布式锁的能力。为了解决这个问题就需要一种跨机器的互斥机制来控制共享资源的访问,这就是分布式锁要解决的问题!

实现分布式锁的方式

三种实现分布式锁的方式

volatile

volatile关键字是线程同步的轻量级实现,所以volatile性能肯定比synchronized关键字要好。但是volatile关键字只能用于变量,而synchronized关键字可以修饰方法以及代码块。synchronized关键字在JavaSE1.6之后进行了优化,主要包括为了减少获得锁和释放锁带来的性能消耗而引入的偏向锁和轻量级锁以及其它各种优化,执行效率有了显著提升,实际开发中使 用 synchronized 关键字的场景还是更多一些。

多线程访问volatile关键字不会发生阻塞,而synchronized关键字可能会发生阻塞。

volatile关键字能保证数据的可见性,但不能保证数据的原子性。synchronized关键字两者都能保证。

volatile关键字主要用于解决变量在多个线程之间的可见性,而synchronized关键字解决的是多个线程之间访问资源的同步性。

volatile和synchronized的区别

添加微信:miraclesComing获取上百G学习资源

 

2019年Java大厂面试(吐血超详细总结)_第1张图片

2019年Java大厂面试(吐血超详细总结)_第2张图片

你可能感兴趣的:(2019年Java大厂面试(吐血超详细总结))