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的重要原因之一