天之道,损有余而补不足,是故虚胜实,不足胜有余。

这篇博文是本人在2017年总结并且发布在GitChat上的博文,主要记录了自己在校园招聘中遇到的各个技术知识点,如今发布在CSDN上,希望对大家有所帮助。

  1. Java 基础知识点
  2. Java 常见集合
  3. 高并发编程(JUC 包)
  4. JVM 内存管理
  5. Java 8 知识点
  6. 络协议相关
  7. 数据库相关
  8. MVC 框架相关
  9. 大数据相关
  10. Linux 命令相关

面试,是大家从学校走向 会的第一步。互联 公司的校园招聘,从形式上说,面试一般分为2-3轮技术面试+1轮HR面试。但是一些公司确实是没有HR面试的,直接就是三轮技术面。技术面试中,面试官一般会先就你所应聘的岗位进行相关知识的考察,也叫基础知识和业务逻辑面试。只要你回答的不是特别差,面试官通常会说:“咱们写个代码吧”,这个时候就开始了算法面试。也就是说,一轮技术面试=基础知识和业务逻辑面试+算法面试。

关于算法面试的总结,各位可以查阅我先前交流的chat:“知名互联 公司校招中常见的算法题”。

本场chat,我们主要从技术面试聊起。技术面试包括:业务逻辑和基础知识面试。

接下来是基础知识面试。Java开发属于后台开发方向,有人说后台开发很坑,因为需要学习的东西太多了。没错,这个岗位就是需要学习好多东西。包括:本语言(Java/C++/PHP)基础、数据库、 络协议、Linux系统、计算机原理甚至前端相关知识都可以考察你,而且,并不超纲。有时候,你 的是后台开发岗,并且熟悉的是Java语言,但是面试官却是C++开发方向的,就是这么无奈~
好了,闲话少说,让我们开始分类讲解常见面试知识点呗。
知名互联 公司校招 Java 开发岗面试知识点解析

(一) Java基础知识点

1)面向对象的特性有哪些/strong>

答:封装、继承和多态。

2)Java中覆盖和重载是什么意思/strong>

解析:覆盖和重载是比较重要的基础知识点,并且容易混淆,所以面试中常见。
答:覆盖(Override)是指子类对父类方法的一种重写,只能比父类抛出更少的异常,访问权限不能比父类的小。被覆盖的方法不能是private的,否则只是在子类中重新定义了一个方法;

重载(Overload)表示同一个类中可以有多个名称相同的方法,但这些方法的参数列表各不相同。

面试官:那么构成重载的条件有哪些/b>

答:参数类型不同、参数个数不同、参数顺序不同。

面试官:函数的返回值不同可以构成重载吗什么/b>

答:不可以,因为Java中调用函数并不需要强制赋值。举例如下:

如下两个方法:

只要编译器可以根据语境明确判断出语义,比如在int x = f();中,那么的确可以据此区分重载方法。不过,有时你并不关心方法的返回值,你想要的是方法调用的其他效果(这常被称为“为了副作用而调用”),这时你可能会调用方法而忽略其返回值,所以如果像下面的调用:

此时Java如何才能判断调用的是哪一个 f() 呢人如何理解这种代码呢strong>所以,根据方法返回值来区分重载方法是行不通的。

3)抽象类和接口的区别有哪些/strong>

答:

  1. 抽象类中可以没有抽象方法;接口中的方法必须是抽象方法;
  2. 抽象类中可以有普通的成员变量;接口中的变量必须是static final类型的,必须被初始化,接口中只有常量,没有变量。
  3. 抽象类只能单继承,接口可以继承多个父接口;
  4. Java8中接口中会有default方法,即方法可以被实现。

面试官:抽象类和接口如何选择/strong>

答:

  1. 如果要创建不带任何方法定义和成员变量的基类,那么就应该选择接口而不是抽象类。

  2. 如果知道某个类应该是基类,那么第一个选择的应该是让它成为一个接口,只有在必须要有方法定义和成员变量的时候,才应该选择抽象类。因为抽象类中允许存在一个或多个被具体实现的方法,只要方法没有被全部实现该类就仍是抽象类。

4)Java和C++的区别:

解析:虽然我们不太懂C++,但是就是会这么问,尤其是三面(总监级别)面试中。

答:

  1. 都是面向对象的语言,都支持封装、继承和多态
  2. 指针:Java不提供指针来直接访问内存,程序更加安全
  3. 继承: Java的类是单继承的,C++支持多重继承; Java通过一个类实现多个接口来实现C++中的多重继承; Java中类不可以多继承,但是!!!接口可以多继承
  4. 内存: Java有自动内存管理机制,不需要程序员手动释放无用内存

5)Java中的值传递和引用传递

解析:这类题目,面试官会手写一个例子,让你说出函数执行结果,详细举例请查阅我的博客:Java值传递和引用传递基础分析。

答:值传递是指对象被值传递,意味着传递了对象的一个副本,即使副本被改变,也不会影响源对象。

引用传递是指对象被引用传递,意味着传递的并不是实际的对象,而是对象的引用。因此,外部对引用对象的改变会反映到所有的对象上。

6)JDK中常用的包有哪些/strong>

答:java.lang、java.util、java.io、java.net、java.sql

7)JDK,JRE和JVM的联系和区别:

答:JDK是 java开发工具包,是java开发环境的核心组件,并提供编译、调试和运行一个java程序所需要的所有工具,可执行文件和二进制文件,是一个平台特定的软件。

JRE是 java运行时环境,是JVM的实施实现,提供了运行java程序的平台。JRE包含了JVM,但是不包含java编译器/调试器之类的开发工具。

JVM是 java虚拟机,当我们运行一个程序时,JVM负责将字节码转换为特定机器代码,JVM提供了内存管理/垃圾回收和安全机制等。这种独立于硬件和操作系统,正是java程序可以一次编写多处执行的原因。

区别:

  1. JDK用于开发,JRE用于运行java程序
  2. JDK和JRE中都包含JVM
  3. JVM是java编程语言的核心并且具有平台独立性

Others:限于篇幅的关系,面试中Java基础知识点还有:反射、泛型、注解等。详见我的博客:

  • Java 注解简单学习
  • Java泛型常见面试题
  • Java反射机制

小结:本节主要阐述了Java基础知识点,这些问题主要是一面面试官在考察,难度不大,适当复习下,应该没什么问题。

(二)Java中常见集合

集合这方面的考察相当多,这部分是面试中必考的知识点。

1)说说常见的集合有哪些吧/strong>

答:Map接口和Collection接口是所有集合框架的父接口:

  1. Collection接口的子接口包括:Set接口和List接口
  2. Map接口的实现类主要有:HashMap、TreeMap、Hashtable、ConcurrentHashMap以及Properties等
  3. Set接口的实现类主要有:HashSet、TreeSet、LinkedHashSet等
  4. List接口的实现类主要有:ArrayList、LinkedList、Stack以及Vector等

(2)HashMap和Hashtable的区别有哪些必问)

答:

  1. HashMap没有考虑同步,是线程不安全的;Hashtable使用了synchronized关键字,是线程安全的;

  2. 前者允许null作为Key;后者不允许null作为Key

3)HashMap的底层实现你知道吗/strong>

答:在Java8之前,其底层实现是数组+链表实现,Java8使用了数组+链表+红黑树实现。此时你可以简单的在纸上画图分析:

9)Atomic关键字:

答:可以使基本数据类型以原子的方式实现自增自减等操作。参考我的博客:concurrent.atomic包下的类AtomicInteger的使用

10)线程池有了解吗strong>(必考)

  1. 如果运行的线程少于corePoolSize,则Executor始终首选添加新的线程,而不进行排队
  2. 如果运行的线程等于或者多于corePoolSize,则Executor始终首选将请求加入队列,而不是添加新线程
  3. 如果无法将请求加入队列,即队列已经满了,则创建新的线程,除非创建此线程超出maxinumPoolSize,在这种情况下,任务将被拒绝。

限于篇幅有限,更多高并发编程中的问题,请各位参阅我的博客:

  • Java多线程编程实战指南(核心篇)读书笔记(一)
  • Java多线程编程实战指南(核心篇)读书笔记(二)
  • Java多线程编程实战指南(核心篇)读书笔记(三)
  • Java多线程编程实战指南(核心篇)读书笔记(四)
  • Java多线程编程实战指南(核心篇)读书笔记(五)

小结:本小节内容涉及到Java中多线程编程,线程安全等知识,是面试中的重点和难点。

(四)JVM内存管理

既然是Java开发面试,那么对JVM的考察当然也是必须的,面试官一般会问你对JVM有了解吗通常都会把我所了解的都说一遍,包括:JVM内存划分、JVM垃圾回收的含义,有哪些GC算法,年轻代和老年代各自的特点统统阐述一遍。

1)JVM内存划分:

  1. 方法区(线程共享):常量、静态变量、JIT(即时编译器)编译后的代码也都在方法区
  2. 堆内存(线程共享):垃圾回收的主要场所。
  3. 程序计数器: 当前线程执行的字节码的位置指示器。
  4. 虚拟机栈(栈内存):保存局部变量、基本数据类型变量以及堆内存中某个对象的引用变量
  5. 本地方法栈 :为JVM提供使用native 方法的服务

2)类似-Xms、-Xmn这些参数的含义:

答:

堆内存分配:

  1. JVM初始分配的内存由-Xms指定,默认是物理内存的1/64
  2. JVM最大分配的内存由-Xmx指定,默认是物理内存的1/4
  3. 默认空余堆内存小于40%时,JVM就会增大堆直到-Xmx的最大限制;空余堆内存大于70%时,JVM会减少堆直到 -Xms的最小限制。
  4. 因此服务器一般设置-Xms、-Xmx相等以避免在每次GC 后调整堆的大小。对象的堆内存由称为垃圾回收器的自动内存管理系统回收。

非堆内存分配:

  1. JVM使用-XX:PermSize设置非堆内存初始值,默认是物理内存的1/64;
  2. 由XX:MaxPermSize设置最大非堆内存的大小,默认是物理内存的1/4。
  3. -Xmn2G:设置年轻代大小为2G。
  4. -XX:SurvivorRatio,设置年轻代中Eden区与Survivor区的比值。

3)垃圾回收算法有哪些/strong>

答:

  1. 引用计数:原理是此对象有一个引用,即增加一个计数,删除一个引用则减少一个计数。垃圾回收时,只用收集计数为0的对象。此算法最致命的是无法处理循环引用的问题。

  2. 标记-清除:此算法执行分两阶段。第一阶段从引用根节点开始标记所有被引用的对象,第二阶段遍历整个堆,把未标记的对象清除。此算法需要暂停整个应用,同时,会产生内存碎片。

  3. 复制算法:此算法把内存空间划为两个相等的区域,每次只使用其中一个区域。垃圾回收时,遍历当前使用区域,把正在使用中的对象复制到另外一个区域中。此算法每次只处理正在使用中的对象,因此复制成本比较小,同时复制过去以后还能进行相应的内存整理,不会出现“碎片”问题。当然,此算法的缺点也是很明显的,就是需要两倍内存空间。

  4. 标记-整理:此算法结合了“标记-清除”和“复制”两个算法的优点。也是分两阶段,第一阶段从根节点开始标记所有被引用对象,第二阶段遍历整个堆,把清除未标记对象并且把存活对象“压缩”到堆的其中一块,按顺序排放。此算法避免了“标记-清除”的碎片问题,同时也避免了“复制”算法的空间问题。

4)root搜索算法中,哪些可以作为root/strong>

答:

  • 被启动类(bootstrap加载器)加载的类和创建的对象
  • JavaStack中的引用的对象(栈内存中引用的对象)。
  • 方法区中静态引用指向的对象。
  • 方法区中常量引用指向的对象。
  • Native方法中JNI引用的对象。

5)GC什么时候开始/strong>

答:GC经常发生的区域是堆区,堆区还可以细分为新生代、老年代,新生代还分为一个Eden区和两个Survivor区。

  1. 对象优先在Eden中分配,当Eden中没有足够空间时,虚拟机将发生一次Minor GC,因为Java大多数对象都是朝生夕灭,所以Minor GC非常频繁,而且速度也很快;

  2. Full GC,发生在老年代的GC,当老年代没有足够的空间时即发生Full GC,发生Full GC一般都会有一次Minor GC。大对象直接进入老年代,如很长的字符串数组,虚拟机提供一个-XX:PretenureSizeThreadhold参数,令大于这个参数值的对象直接在老年代中分配,避免在Eden区和两个Survivor区发生大量的内存拷贝;

  3. 发生Minor GC时,虚拟机会检测之前每次晋升到老年代的平均大小是否大于老年代的剩余空间大小,如果大于,则进行一次Full GC,如果小于,则查看HandlePromotionFailure设置是否允许担保失败,如果允许,那只会进行一次Minor GC,如果不允许,则改为进行一次Full GC。

6)内存泄漏和内存溢出

答:

概念:

  1. 内存溢出指的是内存不够用了。
  2. 内存泄漏是指对象可达,但是没用了。即本该被GC回收的对象并没有被回收
  3. 内存泄露是导致内存溢出的原因之一;内存泄露积累起来将导致内存溢出。

内存泄漏的原因分析:

  1. 长生命周期的对象引用短生命周期的对象
  2. 没有将无用对象置为null

小结:本小节涉及到JVM虚拟机,包括对内存的管理等知识,相对较深。除了以上问题,面试官会继续问你一些比较深的问题,可能也是为了看看你的极限在哪里吧。比如:内存调优、内存管理,是否遇到过内存泄漏的实际案例、是否真正关心过内存等。由于本人实际项目经验不足,这些深层次问题并没有接触过,各位有需要可以上 查阅。

(五)Java 8相关知识点

关于Java8中新知识点,面试官会让你说说Java8你了解多少,下边主要阐述我所了解,并且在面试中回答的Java8新增知识点。

1)HashMap的底层实现有变化:HashMap是数组+链表+红黑树(JDK1.8增加了红黑树部分)实现。

2)JVM内存管理方面,由元空间代替了永久代。

区别:

  1. 元空间并不在虚拟机中,而是使用本地内存
  2. 默认情况下,元空间的大小仅受本地内存限制
  3. 也可以通过-XX:MetaspaceSize指定元空间大小

3)Lambda表达式(也称为闭包),允许我们将函数当成参数传递给某个方法,或者把代码本身当做数据处理。

4)函数式接口:指的是只有一个函数的接口,java.lang.Runnable和java.util.concurrent.Callable就是函数式接口的例子;java8提供了一个特殊的注解@Functionallnterface来标明该接口是一个函数式接口。

5)引入重复注解:Java 8中使用@Repeatable注解定义重复注解。

6)接口中可以实现方法default方法。

7) 注解的使用场景拓宽: 注解几乎可以使用在任何元素上:局部变量、接口类型、超类和接口实现类,甚至可以用在函数的异常定义上。

8) 新的包java.time包

  1. 包含了所有关于日期、时间、时区、持续时间和时钟操作的类
  2. 这些类都是不可变的、线程安全的。

小结:Java8的一些新特性,面试官一般情况下不要求你有多么精通,主要是看看你有没有一些了解。

(六) 络协议相关

络协议方面,考察最多的包括服务器和客户端在三次握手、四次挥手过程中的状态变化;还有 络拥塞控制,及其解决办法等。

1)三次握手、四次挥手示意图:

4)其他问题包括:重定向和转发的区别、动态代理和静态代理的区别等。

Mybatis知识点

关于MyBatis主要考察占位符#和$的区别,区别如下:

  1. #符 将传入的数据都当做一个字符串,会对自动传入的数据加一个双引
  2. $符 将传入的数据直接显示生成SQL中。
  3. #符 存在预编译的过程,,对问 赋值,防止SQL注入。
  4. $符 是直译的方式,一般用在order by ${列名}语句中。
  5. 能用# 就不要用$符

(九)大数据相关知识点

大数据相关是因为我的简历上写了KafKa相关项目,所以面试官会进行提问KafKa相关知识点,我也进行了一些简单概念总结,深层次的实现原理因为并没有特别多的实战经验,所以并不了解。以下概念总结供小伙伴参考。

1)KafKa基本特性:

答:快速持久化、支持批量读写消息、支持消息分区,提高了并发能力、支持在线增加分区、支持为每个分区创建多个副本。

扩展:为什么可以实现快速持久化/strong>

答:KafKa将消息保存在磁盘中,并且读写磁盘的方式是顺序读写,避免了随机读写磁盘(寻道时间过长)导致的性能瓶颈;磁盘的顺序读写速度超过内存随机读写。

2)核心概念:

答:

  • 生产者(Producer):生产消息,并且按照一定的规则推送到Topic的分区中。
  • 消费者(Consumer):从Topic中拉去消息,并且进行消费。
  • 主题(Topic):用于存储消息的逻辑概念,是一个消息集合。
  • 分区(partition):
    1. 每个Topic可以划分为多个分区,每个消息在分区中都会有一个唯一编 offset
    2. kafka通过offset保证消息在分区中的顺序
    3. 同一Topic的不同分区可以分配在不同的Broker上
    4. partition以文件的形式存储在文件系统中。

副本(replica):

  1. KafKa对消息进行了冗余备份,每个分区有多个副本,每个副本中包含的消息是“一样”的。
  2. 每个副本中都会选举出一个Leader副本,其余为Follower副本,Follower副本仅仅将数据从Leader副本拉去到本地,然后同步到自己的Log中。

消费者组(Consumer Group):每个 consumer 都属于一个 consumer group,每条消息只能被 consumer group 中的一个 Consumer 消费,但可以被多个 consumer group 消费。

Broker:

  1. 一个单独的server就是一个Broker
  2. 主要工作:接收生产者发过来的消息,分配offset,并且保存到磁盘中;

Cluster&Controller:

  1. 多个Broker可以组成一个Cluster,每个集群选举一个Broker来作为Controller,充当指挥中心
  2. Controller负责管理分区的状态,管理每个分区的副本状态,监听ZooKeeper中数据的变化等工作

保留策略和日志压缩:

  1. 不管消费者是否已经消费了消息,KafKa都会一直保存这些消息(持久化到磁盘)
  2. 通过保留策略,定时删除陈旧的消息
  3. 日志压缩,只保留最新的Key-Value对

关于副本机制:(加分点)

ISR集合:表示当前“可用”且消息量与Leader相差不多的副本集合。满足条件如下:

  1. 副本所在节点必须维持着与ZooKeeper的连接
  2. 副本最后一条信息的offset与Leader副本的最后一条消息的offset之间的差值不能超过指定的阈值

HW&LEO:

  1. HW标记了一个特殊的offset,当消费者处理消息的时候,只能拉取到HW之前的消息
  2. HW也是由Leader副本管理的
  3. LEO(Log End Offset)是所有副本都会有的一个offset标记

ISR、HW和LEO的工作配合:

  1. producer向此分区中推送消息
  2. Leader副本将消息追加到Log中,并且递增其LEO
  3. Follower副本从Leader副本中拉取消息进行同步
  4. Follower副本将消息更新到本地Log中,并且递增其LEO
  5. 当ISR集合中的所有副本都完成了对offset的消息同步,Leader副本会递增其HW

KafKa的容灾机制:通过分区的副本Leader副本和Follower副本来提高容灾能力

小结:请小伙伴根据自己的简历自行准备学习大数据相关知识点。

(十)Linux常见命令

1)grep、sed以及awk命令

解析:awk命令如果可以掌握,是面试中的一个加分点。

2)文件和目录:

pwd 显示当前目录

ls 显示当前目录下的文件和目录:

  1. ls -F 可以区分文件和目录
  2. ls -a 可以把隐藏文件和普通文件一起显示出来
  3. ls -R 可以递归显示子目录中的文件和目录
  4. ls -l 显示长列表
  5. ls -l test 过滤器,查看某个特定文件信息。可以只查看test文件的信息

3)处理文件方面的命令有:touch、cp、 In、mv、rm、

4)处理目录方面的命令:mkdir

5)查看文件内容:file、cat、more、less、tail、head

6)监测程序命令:ps、top

eg.找出进程名中包括java的所有进程:ps -ef | grep java

top命令 实时监测进程

top命令输出的第一部分:显示系统的概括。

  1. 第一行显示了当前时间、系统的运行时间、登录的用户数和系统的平均负载(平均负载有3个值:最近1min 5min 15min)
  2. 第二行显示了进程的概要信息,有多少进程处于运行、休眠、停止或者僵化状态。
  3. 第三行是CPU的概要信息
  4. 第四行是系统内存的状态

7)ps和top命令的区别:

  1. ps看到的是命令执行瞬间的进程信息,而top可以持续的监视
  2. ps只是查看进程,而top还可以监视系统性能,如平均负载,cpu和内存的消耗
  3. 另外top还可以操作进程,如改变优先级(命令r)和关闭进程(命令k)
  4. ps主要是查看进程的,关注点在于查看需要查看的进程
  5. top主要看cpu,内存使用情况,及占用资源最多的进程由高到低排序,关注点在于资源占用情况

8) 压缩数据

  1. tar -xvf 文件名
  2. tar -zxvf 文件名
  3. tar -cvzf 文件名

9)结束进程:kill PID或者kill all

至此,从十个不同的方面阐述了Java开发面试岗位中所涉及到的重要知识点。加上我上次发布的关于算法面试的chat,我大概将最近一年的时间内的面试笔试经验给大家做了总结分享。接下来,为了给大家提供更多的帮助,我想针对简历方面和大家聊聊,主要包括:制作简历投递简历两方面。

制作简历:

首先,我想先介绍下我的简历都包括哪些部分:

  1. 个人信息:

  2. 教育背景:

  3. 个人亮点:

简历应该突出表现自己优秀的地方,所以我将个人技术博客和github地址放到了相对靠前的位置,使面试官或者HR可以一眼看到。各位小伙伴如果在校期间参加过什么大型竞赛并且获奖,也可以写在明显的位置。

给大家一个小提示,那就是必须对简历上所写的知识点有一定了解,不懂的就不要写上去了,因为你会被问的很惨(即使一面面试官不问,三面面试官也会问的)。

比如说你在简历上写了一个技术A,说自己在项目中使用过技术A,那么面试官就会问该技术A的底层实现、原理等等。如果你回答出来,确实,这是加分项,但是很多时候我们是回答不出来的。

投递简历

投递简历同样很重要,对于并不是出身名校的小伙伴来说,在投递一些互联 公司的时候,可能会面临着简历被刷的可能。这时候内推的重要性就体现出来了。

内推是内部推荐的意思,内推的好处一般有两种:

  1. 内推免简历筛选,直接进入笔试环节。
  2. 内推可以直接获得面试资格,面试失败可以继续参加后续校招大流程。

内推时间点:

  1. 暑期实习校园招聘的内推一般从每年3月份开始。
  2. 秋招的内推从每年8月份开始,持续到九月份。

如何内推/strong>

内推,意味着你要找到公司内部人员进行推荐,内推渠道主要是找自己的师兄师姐。另外可以时常关注 称“全国最大的高校论坛”-北邮人论坛。北邮人论坛资源相当丰富,每年招聘季的内推帖子数不胜数,各位如果有需要,可以关注一下。在牛客 以及赛码 的讨论区内也存在着大量的内推消息,大家可以关注。

结束语

声明:本站部分文章及图片源自用户投稿,如本站任何资料有侵权请您尽早请联系jinwei@zod.com.cn进行处理,非常感谢!

上一篇 2019年11月6日
下一篇 2019年11月6日

相关推荐