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