1.JDK8 新特性
Lambda 表达式-也是函数编程的一种方式(将函数做为参数)
方法的应用,应用已有的java类对象的方法或者构造器。与Lambda表达式相结合,方法应用使得语言构造更加简洁,从而减少代码的冗余
默认方法,默认方法就是一个在接口里边有了一个实现的方法
新工具-新的编译工具,如:Nashorn引擎jjs,类依赖分析器jdeps
Stream API - 把真正的函数式编程风格引入到Java中。
Date Time API - 加强对日期与时间的处理
Optional 类 - Optional 类已经成为Java 8 类库的一部分,用来解决空指针异常
Base64 Java8 内置了Base64 编码的编码器和解析器
2.hashMap 底层实现?当你put一个元素时,在底层结构是如何执行的?
首先需要知道在不同的JDK版本上面hashMap 的实现是有区别的:
JDK8之前: 数组 + 链表
JDK8之后:数组 + 链表 + 红黑树
当你put元素时:
执行步骤:
a.计算该元素的hashCode 值
b.通过计算它的hashCode 值去确定数组下标,数组的初始化16大小,增长因子为0.75
c.当存在哈希冲突是,相同的hashCode 值得到的数组下标就是会一样的,则单纯的数组则不满足,需要链表的支持
d.链表满足长度大于8时转成红黑树,那为啥8呢,遵循泊松分布,红黑树平均查找长度是log(n),长度为8的时候,平均查找长度为3,如果继续使用链表,平均查找长度为8/2=4,这才有转换为树的必要。
3.Spring 中AOP 与IOC的特性,使用场景是在哪些方面?
AOP:面向切面编程,aspect oriented programming
面向切面为的是将日志记录,性能统计,安全控制,事务处理,异常处理等代码从业务逻辑代码中划分出来
主要的功能:日志记录,性能统计,安全控制,事务处理,异常处理等等
IOC:控制反转,就是创建对象的操作交给Spring容器来做。DI 依赖注入,spring通过xml配置文件实例化对象,依赖对象通过
setter方法获取。
4.Spring 注解有哪些?
@Controller 用于标注控制层组件
@Service 用于业务层,也是实现接口
@Component 泛指组件,在不好归类情况下进行标注
@RequestMapping 请求映射,可以指定请求方式
@Resource 装bean注入使用:通过byName自动注入
@Autowired 自动装配bean:通过ByType自动注入
@ResponseBody 响应返回数据类型json
@Transactional 事务
5.RestController 与@Controller的区别?
@restcontroller 注解 等价于 @responseBody + @Controller
@Restcontroller 和@controller 度用于Spring 类是否接受http请求
区别之处:
@restcontroller 返回json数据不需要在方法前面加@ResponseBody注解了;不能返回jsp,HTML页面,视图解析器无法解析jsp,HTML页面,而@controller 可以返回指定的页面;
返回json,xml 或者自定义格式内容到页面显示的话,@restController 单个操作就行,因为它可以自动将实体转成Json格式;而@controller需要加上@responseBody注解
6.数据库优化有哪些方式?
1.选择合适的字段属性
2.使用连接join 代替子查询
3.使用union 代替手动创建的临时表
4.事务
5.锁定表
6.使用外键
7.使用索引
索引应建立在那些将用于JOIN,WHERE判断和ORDERBY排序的字段上。
尽量不要对数据库中某个含有大量重复的值的字段建立索引。比如枚举类型
8.优化查询语句
7.什么是索引?
索引是对数据库表中一列或者多列的值进行排序的一种结构,使用索引可以快速访问数据库表中特定信息。
索引类型5种:
普通索引:仅加速查询
唯一索引:加速查询 + 列值唯一(可以有null)
主键索引:加速查询 + 列值唯一(不可以有null)+ 表中只有一个
复合索引:多列值组成一个索引
全文索引:对文本的内容进行分词,进行搜索
8. 什么是复合索引?
用户可以在多个列建立索引,叫做复合索引。
9.什么是最左匹配原则?
最左匹配原则,以最左为起点任何连续的索引都能匹配上。遇到范围查询时就会停止匹配。
10.Mybatis 中的 号与 符号区别是什么?什么地方会用到${} ?
井号SQL的参数占位符,mybatis会将SQL的#{} 替换成? 号占位符设置参数存在预编译、防止SQL注入
${}是变量占位符,属于静态文本替换,不存在预编译;
需要原样输出的时候可以${}方式;推荐使用#{}方式,安全性高。
11.Spring DI注入的三种方式?
1.构造方法注入
<bean id ="name" class="">
<construcion-arg /> 可以使用这个P 域和 C域的方式;
</bean>
<bean id="userService" class="com.lyu.spring.service.impl.UserService">
<constructor-arg name="userDao" ref="userDaoJdbc"></constructor-arg>
<constructor-arg name="user" ref="user"></constructor-arg>
</bean>
2.setter注入
提供set方法
<!-- 注册userService -->
<bean id="userService" class="com.lyu.spring.service.impl.UserService">
<!-- 写法一 -->
<!-- <property name="UserDao" ref="userDaoMyBatis"></property> -->
<!-- 写法二 -->
<property name="userDao" ref="userDaoMyBatis"></property>
</bean>
3.基于注解的注入
自动注入
@Autowired:spring注解,默认是以byType的方式去匹配与属性名相同的bean的id,
如果没有找到,就通过byName的方式去查找,
12.SpringMVC的工作流程(步骤)?
1、用户发送请求至前端控制器DispatcherServlet
2、DispatcherServlet收到请求调用HandlerMapping处理器映射器。
3、处理器映射器找到具体的处理器,生成处理器对象及处理器拦截器(如果有则生成)一并返回给DispatcherServlet。
4、DispatcherServlet调用HandlerAdapter处理器适配器
5、HandlerAdapter经过适配调用具体的处理器(Controller,也叫后端控制器)。
6、Controller执行完成返回ModelAndView
7、HandlerAdapter将controller执行结果ModelAndView返回给DispatcherServlet
8、DispatcherServlet将ModelAndView传给ViewReslover视图解析器
9、ViewReslover解析后返回具体View
10、DispatcherServlet根据View进行渲染视图(即将模型数据填充至视图中)。
11、DispatcherServlet响应用户
13.Mybatis 动态SQL标签有哪些?
1.select 、insert、update、delete 四个基本的标签
2.resultMap 查询结果集进行自动封装,建议少使用resultType标签
3.parameterMap 入参集合进行封装
<parameterMap id="ParameterMap" type="Student">
<parameter property="studentId" resultMap="ResultMap"></parameter>
<parameter property="studentName" resultMap="ResultMap"></parameter>
</parameterMap>
<resultMap id="ResultMap" type="Student">
<id column="id" property="studentId"></id>
<result column="name" property="studentName"></result>
</resultMap>
4.selectKey 插入数据的时候获取该数据的id值
5.trim 去除
6.where 条件
7.set
注意的是:使用set可以自动去除逗号
<update> update user
<set>
<if test="param.name !=null and param.name !=''">
name = #{param.name},
</if>
</set>
where id = #{param.id}
8.if 结合 test 进行参数的判断
9.foreach 循环遍历
foreach元素属性有item,index,collection,open,separator,close
item:别名
index:下标位置
open:以什么开始
separator:以什么符号作为分隔符
close:以什么结束
<select id="selectByIds" resultMap="baseMap">
select * from user where id in
<foreach collection="list" index="index" item ="item" open="(" separator ="," close=")" >#{item}
</foreach>
</select>
collection 的类型可以list,array,map 对应的参数类型为:List、数组、map集合
10.choose 结合 when 与otherwise进行选择
11.when 当啥时候
12.otherwise 另一种选择
13.bind 绑定
14.resultType 跟resultMap 效果是相同
14.为什么说Mybatis是半自动ORM框架?
自己的理解:ORM指的是对象关系映射,mybatis仅有对字段的关系映射,对象数据以及对象实际关系需要我们自己手动去写SQL去实现和管理,而hibernate是全自动的ORM框架,拥有完整的Javabean对象与数据库表结构自动生成SQL,之前自己动手过Javabean去实现数据库创建表结构是测试。另外,Mybatis拥有自动化SQL语句,在实际开发中都是不定因数而需要我们去重写复杂的SQL语句,hibernate则没有那么灵活好用了。
15.多线程创建的方式有哪些?
多线程创建的方式有四种:
第一种是继承Thead类,重写它的run方法,之后就可以调用
第二种是实现Runnable接口,重写run方式
第三种是实现callable接口,重写call方法
第四种是采用线程池,executorService对象,也是需要配合Runnable进行实现
16.如何更好的描述项目?项目是怎么样的一个流程?
自己觉得这块比较薄弱,虽然是自己做的项目,却不知道如何去表达清楚,如何去说出项目是怎样的一个流程,遇到这里我觉的有必要去借鉴一下大佬的意见。(
1.项目背景 在怎样的条件下进行
2.项目介绍 技术介绍,功能介绍
3.项目参与人员 分工合作,负责人
4.项目进展实施情况 目前进展,项目还剩下的工作量以及规划
5.项目难题及解决 遇到技术难题如何解决的考虑好回答,让你影响深刻的比较有深意问题,采用哪些解决办法
6.项目成果 可以从前端功能点,隐藏bug;从后端功能接口是否完善,是否存在容错问题
7.总结反思 从0到1的这个过程你收获了多少?后期开发有啥建议啥的?