美文网首页
Java面试题集七

Java面试题集七

作者: 王乐生 | 来源:发表于2020-09-22 23:51 被阅读0次

1、Set与List的区别

1)list方法允许重复的对象,set方法不允许有重复的对象

2)list可以插入多个null元素,set只允许插入一个null元素

3)list是一个有序的容器,保持了每个元素的插入顺序。set是无序容器,无法保证每个元素的存储顺序

2、MyBatis的#{}与${}的区别

#{} 这种取值是编译好SQL语句再取值    即    #{}:动态解析 -> 预编译 -> 执行

${} 这种是取值以后再去编译SQL语句    即    ${}:动态解析 -> 编译 -> 执行

#传入的参数在SQL中显示为字符串(当成一个字符串),会对自动传入的数据加一个双引号。

$传入的参数在SqL中直接显示为传入的值

${ } 变量的替换阶段是在动态 SQL 解析阶段,而 #{ }变量的替换是在 DBMS 中。

#可以防止SQL注入的风险(语句的拼接);但$无法防止Sql注入。

$方式一般用于传入数据库对象,例如传入表名。

大多数情况下还是经常使用#,一般能用#的就别用$;但有些情况下必须使用$,例:MyBatis排序时使用order by 动态参数时需要注意,用$而不是#。

3、为什么要有无参构造

java中会默认提供一个无参的构造函数

无参构造函数,主要用于在子类创建对象的使用,java程序在执行子类的构造方法之前,会去调用父类的构造方法,可以显示的指定super()某一个父类构造函数,如未显示指定super(),系统会自动调用父类中没有参数的构造方法

4、HashMap与ConcurentHashMap的区别

HashMap:底层数组+链表实现,可以存储Null键和null值,线程不安全;初始size为16,扩容每次都是oldsize*2;插入元素后才判断该不该扩容,有可能无效扩容;计算index方法:index=hash&(tab.length-1)

ConcurrentHashMap:底层采用分段的数组+链表,线程安全;通过把整个map分为N个Segment,可以提供相同的线程安全,但是效率提升N倍(默认提升16倍);扩容(段内扩容)段内元素超过该段对应的Entry数组长度的75%触发扩容,不会对整个map进行扩容,插入前检测需不需要扩容,有效避免无效扩容。

5、final与static的区别,什么时候用static

final:

1)final关键字修饰变量:变量必须在构造对象时就初始化;如果是基本数据类型,那么这个变量一旦初始化就不能修改;如果是引用数据则不能修改它的引用;

2)final关键字修饰方法:表明这个方法不能被子类重写,防止类修改它的含义

3)final修饰类:表明这个类不能被继承;final类中的所有成员方法都会被隐式的指定为final方法,但是成员变量可以是final也可以是非final。

static:

1)static修饰方法:静态方法是不在对象上执行的方法,不需要类的实例化,可以直接通过类名来调用;在类加载时分配内存空间,在调用时执行,静态方法只能调用静态变量和静态方法,且不能被重写;

2)static关键字修饰代码块:静态代码块只在类加载时执行一次,静态代码块及非静态代码块的执行顺序(1、先加载父类静态字段或者静态语句块2、子类的静态字段或者静态语句块3、父类的普通变量及语句块4、父类构造函数被加载5、子类变量或者语句块被加载6、子类构造方法被加载)

3)static关键字修饰内部类:静态内部类的创建不依赖与外部类,创建普通内部类之前需要先创建外部类的对象(外部类.内部类 内部类对象 = 外部类对象.new 内部类();),而创建静态内部类之前不需要先创建外部类,可以直接创建静态内部类。(外部类.内部类 内部类对象 = new 外部类.内部类(););静态内部类可以调用外部类的静态变量和静态方法,但不能调用外部类的非静态方法和非静态方法

6、数据库索引的好处

创建索引的条件:

1)较为频繁的作为查询的条件的字段应该创建索引;

2)唯一性太差的字段不适合单独创建索引,即使频繁作为查询条件;

3)更新非常频繁的字段不适合创建索引;

4)不会出现在WHERE字句中的字段不该创建索引,也就是不常作为查询条件的字段不创建索引

索引的优点:

1)通过创建唯一性索引,可以保证数据库表中每一行数据的唯一性;

2)可以大大加快数据的检索速度,这是创建索引的主要原因

3)可以加速表与表之间的连接,特别是在实现数据的参考完整性方面特别有意义

4)在使用分组和排序子句进行数据检索时,同样可以显著减少查询中分组和排序时间

5)通过使用索引,可以在查询的过程中,使用优化隐藏器,提高系统的性能

缺点:

1)创建索引和维护索引要耗费时间,这个时间随着数据量增加而增加

2)索引需要占物理空间,除了数据表占据数据空间之外,每一个索引还要占一定的物理空间

3)、对表中的数据进行增加、删除和修改的时候,索引也要动态的维护,这样就降低了维护的速度

7、在创建日期列创建索引是否可行

可行,至于建立聚集索引或者是非聚集索引,那要看你这个时间字段的具体情况以及使用或变更频繁程度

8、排序不能使用order by

9、使用maven如果jar包冲突了怎么结解决

产生原因:依赖传递;

处理:

1、Maven默认处理策略(最短路径优先、最先声明优先)

2、移除依赖:用于排除某项依赖的依赖jar包(借助Maven Helper插件中的Dependency Analyzer分析冲突的jar包、手动排除)

10、对称加密算法和非对称加密算法的区别,各自有哪些代表

对称加密算法:加密和解密使用相同的密钥;主要有AES、DES、ADES

非对称加密算法:RSA、DSA、ECC

11、Springboot的热部署

原理:使用了两个ClassLoader,一个Classloder加载那些不会改变的类(第三方Jar包),另一个Classloader加载会更改的类,称为restart ClassLoader,这样在有代码更改的时候,原来的restart ClassLoader被丢弃,重新创建一个restart ClassLoader,由于需要加载的类比较少,所以实现了较快的重启时间。

springBoot的热部署方式:

1)使用springloaded配置pom.xml文件,使用mvn springboot:run启动

2)使用springloaded本地加载启动,配置jvm参数 -javaagent:<jar包地址>-noverify

3)使用devtools工具包,操作简单,但是每次需要重新部署

12、数据库事物

数据库事物是访问并可能操作各种数据项的一个数据库操作序列,这些操作要么全部执行要么全部不执行,是一个不可分割的工作单位。

13、HashMap与HashTable的区别

1、HashTable的key和value都不能为null,线程安全,实现线程安全是在修改数据时锁住整个HashTable,效率低;HashMap是线程不安全的,key和value可以为null

2、HashTable的初始化size为11,扩容为oldsize*2+1;HashMap初始size为16,扩容为oldsize*2;

14、==和equals的区别

1)、==如果比较的是基本数据类型的变量,则直接比较其存储的值是否相等;如果比较的是引用类型,那么则比较所指向的对象的地址是否相同

2)、对于euqals方法比较的是否是同一个对象,首先equals不能作用于基本数据类型的变量;其次equals方法存在与Object类中,而Object类是所有类的直接或者间接父类,所有类中的equals都是继承Object类,在没有重写equals的方法的类中,调用equals方法其实和==效果一样,也是比较的引用类型的变量所指向的对象的地址,不过java提供的类大部分都重写了equals方法,重写后的equals方法一般都是比较两个对象的值,比如String类

15、MyISAM与InnoDB 的区别

1)、InnoDB支持事物,MyISAM不支持,对于InnoDB每条SQL都默认封装成事物自动提交,这样会影响速度,所以最好把多条SQL语句放在begin和commit之间,组成一个事物

2)、InnoDB支持外键,MyISAM不支持。对一个包含外键的InnoDB表转为MyISAM会失败

3)、InnoDB是聚集索引,MyISAM是非聚集索引。聚簇索引的文件存放在主键索引的叶子节点上,因此 InnoDB 必须要有主键,通过主键索引效率很高。但是辅助索引需要两次查询,先查询到主键,然后再通过主键查询到数据。因此,主键不应该过大,因为主键太大,其他索引也都会很大。而 MyISAM 是非聚集索引,数据文件是分离的,索引保存的是数据文件的指针。主键索引和辅助索引是独立的。

4)、InnoDB不保存表的具体行数,执行 select count(*) from table 时需要全表扫描。而MyISAM用一个变量保存了整个表的行数,执行上述语句时只需要读出该变量即可,速度很快

5)、InnoDB最小的锁粒度是行锁,MyISAM的最小的锁粒度是表锁。一个更新语句会锁住整张表,导致其他查询和更新都会被阻塞,因此并发访问受限。这也就是MySQL将默认存储引擎从MyISAM变成InnoDB的重要原因之一

相关文章

  • Java面试题集

    Java面试题集(1-50) Java面试题集(51-70) Java面试题集(71-85) Java面试题集(8...

  • Android面试总结二

    参考文章 40个Android面试题Java面试题集Android名企面试题及知识点整理Android面试题收集较...

  • Java面试题集七

    1、Set与List的区别 1)list方法允许重复的对象,set方法不允许有重复的对象 2)list可以插入多个...

  • Java面试题收藏

    Java面试题收藏 一篇比较好的面试题整理: Java面试题集 自己的一些收藏: 静态变量和实例变量的区别 静态变...

  • Java面试题及答案整理(图文)

    Java面试题集涵盖了java所有的知识点,及java项目开发中涉及到的各种框架 。包含了 Java 集合、JVM...

  • Java面试题详解(PDF版整理)

    Java面试题集涵盖了java所有的知识点,及java项目开发中涉及到的各种框架 。包含了 Java 集合、JVM...

  • Java面试题汇总

    Java面试题总结 Java面试题总结一Java面试题总结二

  • 面试题

    Java面试题集 - 简书 Java内部类详解 - 海 子 - 博客园 记一次 Android 面试 - 简书 A...

  • 太赞了,2020 最新 Java 面试题出炉!(带全部答案)

    今天给大家带来一套 2020最新整理的Java 面试题,独家整理,禁止剽窃!!! 题库非常全面,包括 Java 集...

  • java实习生面试题题库

    java实习生面试题,java基础面试,java面试题2018及答案,java面试题库 1、[一个.java源文件...

网友评论

      本文标题:Java面试题集七

      本文链接:https://www.haomeiwen.com/subject/tsmwyktx.html