Java开发面试题整理(2019春招)

前端之家收集整理的这篇文章主要介绍了Java开发面试题整理(2019春招)前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

<div id="article_content" class="article_content clearfix csdn-tracking-statistics" data-pid="blog" data-mod="popu_307" data-dsm="post">
<div id="content_views" class="htmledit_views">

一、Java基础部分

1. HashMap和Hashtable各有什么特点,它们有什么区别?(必背题,超级重要)

2. HashMap的工作原理?

3. ArrayList和LinkList各自的特点和区别?

1、ArrayList和LinkedList可想从名字分析,它们一个是Array(动态数组)的数据结构,一个是Link(链表)的数据结构,此外,它们两个都是对List接口的实现。前者是数组队列,相当于动态数组;后者为双向链表结构,也可当作堆栈、队列、双端队列

2、当随机访问List时(get和set操作),ArrayList比LinkedList的效率更高,因为LinkedList是线性的数据存储方式,所以需要移动指针从前往后依次查找。

3、当对数据进行增加和删除的操作时(add和remove操作),LinkedList比ArrayList的效率更高,因为ArrayList是数组,所以在其中进行增删操作时,会对操作点之后所有数据的下标索引造成影响,需要进行数据的移动。

4、从利用效率来看,ArrayList自由性较低,因为它需要手动的设置固定大小的容量,但是它的使用比较方便,只需要创建,然后添加数据,通过调用下标进行使用;而LinkedList自由性较高,能够动态的随数据量的变化而变化,但是它不便于使用。

5、ArrayList主要控件开销在于需要在lList列表预留一定空间;而LinkList主要控件开销在于需要存储结点信息以及结点指针信息。

4. RESTFul风格接口的特点?

5. 面向对象的七种设计原则

面向对象七大设计原则:

1、 开闭原则(OCP:Open Closed Principle)

核心:对扩展开放,对修改关闭。即在设计一个模块的时候,应当使这个模块可以在不被修改的前提下被扩展。

  • 根据开闭原则,在设计一个软件系统模块(类,方法)的时候,应该可以在不修改原有的模块(修改关闭)的基础上,能扩展其功能(扩展开放)。

2、 里氏替换原则(LSP:Liskov Substitution Principle)

核心:在任何父类出现的地方都可以用他的子类来替代(子类应当可以替换父类并出现在父类能够出现的任何地方)

  • 1.子类必须完全实现父类方法。在类中调用其他类是务必要使用父类或接口,如果不能使用父类或接口,则说明类的设计已经违背了LSP原则。
  • 2.子类可以有自己的个性。子类当然可以有自己的行为和外观了,也就是方法属性
  • 3.覆盖或实现父类方法时输入参数可以被放大。即子类可以重载父类方法,但输入参数应比父类方法中的大,这样在子类代替父类的时候,调用的仍然是父类方法。即以子类中方法的前置条件必须与超类中被覆盖的方法的前置条件相同或者更宽松。
  • 4.覆盖或实现父类方法输出结果可以被缩小。

3、 单一职责原则(SRP:Single responsibility principle)

核心:和增强内聚性(高内聚,低耦合)

  • 类被修改的几率很大,因此应该专注于单一的功能。如果你把多个功能放在同一个类中,功能之间就形成了关联,改变其中一个功能,有可能中止另一个功能,这时就需要新一轮的测试来避免可能出现的问题。

4、 接口隔离原则(ISP:Interface Segregation Principle)

核心思想:不应该强迫客户程序依赖他们不需要使用的方法。接口分离原则的意思就是:一个接口不需要提供太多的行为,一个接口应该只提供一种对外的功能,不应该把所有的操作都封装到一个接口当中.

  • 分离接口的两种实现方法:
  • 1.使用委托分离接口。(Separation through Delegation)
  • 2.使用多重继承分离接口。(Separation through Multiple Inheritance)

5、 依赖倒置原则(DIP:Dependence Inversion Principle)

核心:要依赖于抽象,不要依赖于具体的实现

6、 迪米特原则(最少知识原则)(LOD:Law of Demeter)

核心思想:一个对象应当对其他对象有尽可能少的了解,不和陌生人说话。(类间解耦,低耦合)意思就是降低各个对象之间的耦合,提高系统的可维护性;在模块之间只通过接口来通信,而不理会模块的内部工作原理,可以使各个模块的耦合降到最低,促进软件的复用
注:

7、 组合/聚合复用原则(CRP:Composite Reuse Principle)

核心思想:尽量使用对象组合,而不是继承来达到复用的目的。该原则就是在一个新的对象里面使用一些已有的对象,使之成为新对象的一部分:新的对象通过向这些对象的委派达到复用已有功能的目的。

复用的种类:

  • 1.继承
  • 2.合成聚合

注:在复用时应优先考虑使用合成聚合而不是继承

6. 谈谈堆和栈的区别!

a.堆栈空间分配

  • 栈(操作系统):由操作系统自动分配释放 ,存放函数的参数值,局部变量的值等。其操作方式类似于数据结构中的栈。
  • 堆(操作系统): 一般由程序员分配释放, 若程序员不释放,程序结束时可能由OS回收,分配方式倒是类似于链表

b.堆栈缓存方式

  • 栈使用的是一级缓存, 他们通常都是被调用时处于存储空间中,调用完毕立即释放。
  • 堆则是存放在二级缓存中,生命周期由虚拟机的垃圾回收算法来决定(并不是一旦成为孤儿对象就能被回收)。所以调用这些对象的速度要相对来得低一些。

c.堆栈数据结构区别

  • 堆(数据结构):堆可以被看成是一棵树,如:堆排序。
  • 栈(数据结构):一种先进后出的数据结构。

7. 谈谈你所了解的设计模式,并简单描述其特点和用法,或简单写一个某某设计模式!

1. 单例设计模式
2. 工厂设计模式
3. 代理模式
4. 观察者设计模式
5. 适配器模式
6. 策略模式
7. 门面模式
8. 桥接模式

来一个参考链接

注:设计模式有很多,这里列举几种常用的!读者需要自行将这几种设计模式理解清楚!前五种是常用也是常考的!

8. 熟悉HTTP基本的状态码!

一些常见的状态码为:

9. List、Set和Map的特点和区别(重点)

List

  • 1.可以允许重复的对象。
  • 2.可以插入多个null元素。
  • 3.是一个有序容器,保持了每个元素的插入顺序,输出的顺序就是插入的顺序。
  • 4.常用的实现类有 ArrayList、LinkedList 和 Vector。ArrayList 最为流行,它提供了使用索引的随意访问,而 LinkedList 则对于经常需要从 List 中添加或删除元素的场合更为合适。

Set

  • 1.不允许重复对象
  • 2.无序容器,你无法保证每个元素的存储顺序,TreeSet通过 Comparator 或者 Comparable 维护了一个排序顺序。
  • 3.只允许一个 null 元素
  • 4.Set 接口最流行的几个实现类是 HashSet、LinkedHashSet 以及 TreeSet。最流行的是基于 HashMap 实现的 HashSet;TreeSet 还实现了 SortedSet 接口,因此 TreeSet 是一个根据其 compare() 和 compareTo() 的定义进行排序的有序容器。

Map

  • 1.不是collection的子接口或者实现类。Map是一个接口。
  • 2.Map 的 每个 Entry 都持有两个对象,也就是一个键一个值,Map 可能会持有相同的值对象但键对象必须是唯一的。
  • 3.TreeMap 也通过 Comparator 或者 Comparable 维护了一个排序顺序。
  • 4.Map 里你可以拥有随意个 null 值但最多只能有一个 null 键。
  • 5.Map 接口最流行的几个实现类是 HashMap、LinkedHashMap、Hashtable 和 TreeMap。(HashMap、TreeMap最常用)

10.监听器、过滤器、拦截器、servlet的区别

11. 当在浏览器输入一个网址,所要经过的全部在过程,请详细描述!

浏览器访问某地址的详细过程:

在这里插入<a href=图片描述">

12. 简单描述Spring的特点:

二、数据库基础部分

1. 详细描述几种你所熟悉的优化数据库的方式。

1、选取最适用的字段属性
2、使用连接(JOIN)来代替子查询(Sub-Queries)
3、使用联合(UNION)来代替手动创建的临时表
4、事务
5、锁定表
6、使用外键
7、使用索引
8、优化的查询语句

参考链接

2. 数据库的视图和索引都有什么特点,有什么区别?

视图:

404_173@ create view viewName(参数列表/可以不写这样就是默认和下面的select一样) as select * create table viewdemo(id primary key,name (10),score as select* score) as select name,score from viewdemo; 修改视图: 删除视图: drop view drop view view2;

 

索引 :

404_173@ ALTER TABLE table_name ADD [UNIQUE|FULLTEXT] [INDEX| [inex_name] (col_name [length ],...) [ASC|DESC]

 

404_173@ ALTER TABLE book ADD INDEX indexName( bookname(30 ALTER TABLE book ADD INDEX BkAndInfoIdx( authors(20),info(50 前提是这个表的存储引擎为 MyISAM)

 

使用 create index 创建索引:

语法:

404_173@ CREATE [UNIQUE|FULLTEXT] [INDEX| ON table_name ( col_name[ length ],... ) [ASC | 4删除索引: DROP INDEX index_name ON table_name ;

后续还会有补充,姑且先写到这吧!

我有一个微信公众号,经常会分享一些Java技术相关的干货;

如果你喜欢我的分享,可以用微信搜索“Java团长”或者“javatuanzhang”关注。

Java开发面试题整理(2019春招)

猜你在找的Java面试题相关文章