说道找工作大家第一想到的应该就是面试过程中的面试题,然后就是会想到考官会问那些面试题呢?我应该做哪些准备呢?这些都应该根据你所要面试的职位来决定。
这里针对java软件工程师的面试过程中为大家整理了一套关于面试方面的常见的面试题目。
1. list、map和set什时候用?彼此间的区别和联系?
(1)list列表是顺序存放对象的,可以有相同的对象,通过索引存取;一般在能直接使用数组的时候,就有使用列表
(2)set集合:集合是无序存放对象的,其中不能有重复的对象(唯一的,回忆高中时候数学中学习的集合特性),集合没有索引,只能遍历次存取;一般用于存放无序的(指顺序不重要)不能重复的对象
(3)Map映射:映射,存放的是键与值的映射,其中键是唯一的(不能有重复对象),而值可以有重复的对象,存的时候,需要指定键和对应的值,取的时候可以根据键名取到值,也可以遍历;一般在用于存放具有对应关系的键值对的时候用;
(4)三者的区别和联系:三者都是接口,List与Set具有相似性,它们都是单列元素的集合,list,set是继承自collection,而map不是,list里可以有重复元素,有先后顺手,Set里面不允许有重复的元素,而且无序,Map 保存key-value值,value可多值。
2. 说一下多态的表现形式?
(1)重载,重写,重载Overload表示同一个类中可以有多个名称相同的方法,但这些方法的参数列表各不相同
(2)重写Override表示子类中的方法可以与父类中的某个方法的名称和参数完全相同,通过子类创建的实例对象调用这个方法时,将调用子类中的定义方法,这相当于把父类中定义的那个完全相同的方法给覆盖了,这也是面向对象编程的多态性的一种表现,只能比父类抛出更少的异常,或者是抛出父类抛出的异常的子异常,子类方法的访问权限只能比父类的更大,不能更小。如果父类的方法是private类型,那么,子类则不存在覆盖的限制,相当于子类中增加了一个全新的方法
3. 数据的加密模式?加密模式的顺序?
(1)对称式和非对称式,顺序:传输加密,数据存储加密,数据完整型的鉴别,密钥管理;
4. 问到hasshmap底层数据结构,arraylist-linklist区别和为什么有这样的区别;数组的比较方法;基本类型和引用数据类型的区别;问接口和抽象类的区别;
(1)HashMap是线程序不安全的,不是同步的
HashMap可以让你将空值作为一个表的条目的key或value
Hashmap实际上是一个数组和链表的结合体,在java编程语言中,最基本的结构就是两种,一个是数组,另外一个是模拟指针(引用),所有的数据结构都可以用这两个基本结构来构造的,hashmap也不例外。Hashmap实际上是一个数组和链表的结合体.
(2)区别:ArrayList是实现了基于动态数组的数据结构,LinkedList基于链表的数据结构,对于随机访问get和set,ArrayList觉得优于LinkedList,因为LinkedList要移动指针,.对于新增和删除操作add和remove,LinedList比较占优势,因为ArrayList要移动数据,若只对单条数据插入或删除,ArrayList的速度反而优于LinkedList。但若是批 量随机的插入删除数据,LinkedList的速度大大优于ArrayList. 因为ArrayList每插入一条数据,要移动插入点及之后的所有数据。 这一点我做了实验。在分别有200000条“记录”的ArrayList和LinkedList的首位插入20000条数据,LinkedList耗时约 是ArrayList的20分之1。
5. 如何配置安装jdk?如何判断其配置成功?
(1)首先安装JDK要看你电脑的位数,选择32位或64位的jdk版本,建议使用1.6版本以上,1.7版本一下;
(2)从Oracle官网下载JDK安装包。
(3)安装包下载完成后,双击安装包进行安装,安装路径可以使用默认路径。
(4)安装完成后,还需要进行环境变量的配置,在系统环境变量的用户变量里面添加一个变量名为 JAVA_HOME环境变量,然后在变量值处填写上JDK安装目录的bin文件夹的路径,如:C:\ProgramFiles\Java \jdk1.7.0_79,然后再添加一个变量名为Path的变量,变量值填写为%JAVA_HOME%\bin;即可。
(5)可以写一个简单的java程序来测试JDK是否已安装成功:public class Test{public static void main(String args[]){System.out.println("This is a test program.");}}将上面的这段程序保存为文件名为Test.java的文件。(注意Test是程序的公共类,必须和文件名一致,包括大小写)然后打开命令提示符窗口,cd到你的Test.java所在目录,然后键入下面的命令:javac Test.java (回车)java Test 此时如果看到打印出来This is a test program.的话说明安装成功了,如果没有打印出这句话,你需要仔细检查一下你的配置情况。
6. java常见的数据类型是什么和对应的包装类是什么?java的隐式类型?assert什么时候使用?
(1)int, double, float, long, short, boolean, byte, char
(2)Integer.Double,Float,Long,Short,Boolean,Byte,Characher.
(3)java的隐式类型是int,byte,short,char都可以隐含转换为int ,
(4)一般来说,assertion用于保证程序最基本、关键的正确性。assertion检查通常在开发和测试时开启。为了提高性能,在软件发布后,assertion检查通常是关闭的;
7. object类型中有哪些方法?
(1)equals()、hashCode()、wait()、toString(),finalize(),notify(),notifyAll(),wait(),
8. final、finallly和finalize的区别?
(1)final 用于声明属性,方法和类,分别表示属性不可变,方法不可覆盖,类不可继承。
内部类要访问局部变量,局部变量必须定义成final类型,例如,一段代码……
finally是异常处理语句结构的一部分,表示总是执行。
finalize是Object类的一个方法,在垃圾收集器执行的时候会调用被回收对象的此方法
9. LinkedList和ArrayList的区别?继承的接口?
(1)ArrayList是使用数组方式存储数据,此数组元素数大于实际存储的数据以便增加和插入元素,它们都允许直接按序号索引元素,但是插入元素要涉及数组元素移动等内存操作,所以索引数据快而插入数据慢
LinkedList使用双向链表实现存储,按序号索引数据需要进行前向或后向遍历,但是插入数据时只需要记录本项的前后项即可,所以插入速度较快。
LinkedList也是线程不安全的,LinkedList提供了一些方法,使得LinkedList可以被当作堆栈和队列来使用
(2)list接口;ArrayList是最常用的List实现类,内部是通过数组实现的,它允许对元素进行快速随机访问; Vector与ArrayList一样,也是通过数组实现的,不同的是它支持线程的同步,即某一时刻只有一个线程能够写Vector,避免多线程同时写而引起的不一致性,但实现同步需要很高的花费,因此,访问它比访问ArrayList慢。LinkedList是用链表结构存储数据的,很适合数据的动态插入和删除,随机访问和遍历速度比较慢。另外,接口中没有定义的方法 get,remove,insertList,专门用于操作表头和表尾元素,可以当作堆栈、队列和双向队列使用。LinkedList没有同步方法。如果 多个线程同时访问一个List,则必须自己实现访问同步。一种解决方法是在创建 List时构造一个同步的List:
10:用Java编程一个会导致死锁的程序,你将怎么解决?
这是我最喜欢的Java线程面试问题,因为即使死锁问题在写多线程并发程序时非常普遍,但是很多侯选者并不能写deadlock free code(无死锁代码?),他们很挣扎。只要告诉他们,你有N个资源和N个线程,并且你需要所有的资源来完成一个操作。为了简单这里的n可以替换为2,越大的数据会使问题看起来更复杂。通过避免Java中的死锁来得到关于死锁的更多信息。
11, 什么是原子操作,Java中的原子操作是什么?
非常简单的java线程面试问题,接下来的问题是你需要同步一个原子操作。
12,Java中的volatile关键是什么作用?怎样使用它?在Java中它跟synchronized方法有什么不同?
自从Java 5和Java内存模型改变以后,基于volatile关键字的线程问题越来越流行。应该准备好回答关于volatile变量怎样在并发环境中确保可见性、顺序性和一致性。
13,什么是竞争条件?你怎样发现和解决竞争?
这是一道出现在多线程面试的高级阶段的问题。大多数的面试官会问最近你遇到的竞争条件,以及你是怎么解决的。有些时间他们会写简单的代码,然后让你检测出代码的竞争条件。可以参考我之前发布的关于Java竞争条件的文章。在我看来这是最好的java线程面试问题之一,它可以确切的检测候选者解决竞争条件的经验,or writing code which is free of data race or any other race condition。关于这方面最好的书是《Concurrency practices in Java》。
14, 你将如何使用thread dump?你将如何分析Thread dump?
在UNIX中你可以使用kill -3,然后thread dump将会打印日志,在windows中你可以使用”CTRL+Break”。非常简单和专业的线程面试问题,但是如果他问你怎样分析它,就会很棘手。
15、mysql分页方式
物理分页
逻辑分页
16、单例模式怎么优化
考虑是否要取消单例采用其他方式实现
17、redis
4.1、内存分配
一台服务器10G内存,要在该服务器部署一个redis实例,同时即需要写也要读,如果直接给redis分配半数以上的内存,服务器很可能会垮掉,因为redis在写操作的时候回fork一个新的线程,同时分配相同内存给新线程,不考虑虚拟内存的话,写操作时内存占用状况也就是,当前redis物理内存 * 2 > 10 。所以服务器会垮掉。在分配内存时需要注意,尽量将内存设置在半数以下。
4.2、数据结构
4.3、常用操作、原子操作
4.4、存储结构。单向链表
18、http请求网络异常解决方案
根据异常状况和请求状况进行分类。考虑是否需要异步请求,实时数据交互考虑循环请求2次,而且一般在进行网络通讯的过程中,对于一些比较重要的交互数据会采用日志记录的方式来记录本次通讯的状况。后期可以通过日志分析异常的主要原因,并针对性解决。
19、关于内存溢出问题的查找方式
原因分析:
1.内存中加载的数据量过于庞大,如一次从数据库取出过多数据;
2.集合类中有对对象的引用,使用完后未清空,使得JVM不能回收;
3.代码中存在死循环或循环产生过多重复的对象实体;
4.使用的第三方软件中的BUG;
5.启动参数内存值设定的过小;
解决思路:
第一步,修改JVM启动参数,直接增加内存。(-Xms,-Xmx参数一定不要忘记加。)
第二步,检查错误日志,查看“OutOfMemory”错误前是否有其它异常或错误。
第三步,对代码进行走查和分析,找出可能发生内存溢出的位置。
使用工具:
常用的有 BoundsCheaker、Deleaker、Visual Leak Detector等
20、事务
20.1、事物的作用(事物的传播机制)是保证数据的原子性一致性隔离性和永久性。一般说为了保证数据的原子性即可。
20.2、事物的隔离级别,脏读*、不可重复读**、幻读***、Serializable****。(*代表权重)
MySQL:AUTOCOMMIT控制事务行为。默认为1每执行一条sql都会认为一个事务,自动提交。设置为0时只有在遇到commit时才会认为一条完整的事务然后提交。
21数据库中的乐观锁和悲观锁
根据不同类型可以对数据设置不同的锁权限
** 乐观 悲观 锁 主要是作用在并发访问控制**
· 悲观锁 假定会发生并发冲突,屏蔽任何违反数据完整的操作
· 乐观锁 假定不会发生冲突,只有在提交操作时检查是否违反数据的完整性
22 drop, delete truncate的区别
三者都是删除的意思,但是三者个有些区别
· delete和truncate只删除表的数据不删除表的结构
· 速度 drop > truncate > delete
· 想删除部分数据时, delete 删除时要带上where语句
· 保留表而想删除所有的数据时用truncate
23 超键 候选键 主键 外键 区别
超键在关系中能唯一标识元组的属性集称为关系模式的超键,一个或多个属性组合在一起作为超键。
候选键 最下超键,没有冗余元素的超键
主键 数据库中表中唯一和完整标识的数据列或属性集合。
外键 在一个表中存在另外一个表的主键叫做外键
24 数据库三大范式介绍
· 1NF 字段是最小单元,不可再分
· 2NF 满足1NF 表中字段必须完全依赖全部主键而并非部分主键
· 3NF 满足2NF,非主键外的所有字段必须互不依赖
25.数据库事务的四个特性及含义
数据库事务transanction正确执行的四个基本要素。ACID,原子性(Atomicity)、一致性(Correspondence)、隔离性(Isolation)、持久性(Durability)。
原子性:整个事务中的所有操作,要么全部完成,要么全部不完成,不可能停滞在中间某个环节。事务在执行过程中发生错误,会被回滚(Rollback)到事务开始前的状态,就像这个事务从来没有执行过一样。
一致性:在事务开始之前和事务结束以后,数据库的完整性约束没有被破坏。
隔离性:隔离状态执行事务,使它们好像是系统在给定时间内执行的唯一操作。如果有两个事务,运行在相同的时间内,执行相同的功能,事务的隔离性将确保每一事务在系统中认为只有该事务在使用系统。这种属性有时称为串行化,为了防止事务操作间的混淆,必须串行化或序列化请求,使得在同一时间仅有一个请求用于同一数据。
持久性:在事务完成以后,该事务所对数据库所作的更改便持久的保存在数据库之中,并不会被回滚。
Java热点新闻