Java面试题集七

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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 201,681评论 5 474
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 84,710评论 2 377
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 148,623评论 0 334
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,202评论 1 272
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,232评论 5 363
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,368评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,795评论 3 393
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,461评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,647评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,476评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,525评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,226评论 3 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,785评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,857评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,090评论 1 258
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,647评论 2 348
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,215评论 2 341