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的这个过程你播种了多少?前期开发有啥倡议啥的?