目录
多对多的表设计
多对多的就是加一张中间表 ,将两个表的主键放入这个表中
多对多的关系再开发中也是比较常见的,比如说像老师与学生的关系,一个学生可以有多个代课老师,一个代课老师也可以有多个学生。再比如,学生与课程的关系,一个学生可以选修多门课程,而一门课程也可以供多个学生选修。
类加载器的实现过程
1.加载 加载时类加载的第一个过程,在这个阶段,将完成一下三件事情:
通过一个类的全限定名获取该类的二进制流。
将该二进制流中的静态存储结构转化为方法去运行时数据结构。
在内存中生成该类的Class对象,作为该类的数据访问入口。
2.验证 验证的目的是为了确保Class文件的字节流中的信息不回危害到虚拟机.在该阶段主要完成以下四钟验证:
文件格式验证:验证字节流是否符合Class文件的规范,如主次版本号是否在当前虚拟机范围内,常量池中的常量是否有不被支持的类型.
元数据验证:对字节码描述的信息进行语义分析,如这个类是否有父类,是否集成了不被继承的类等。
字节码验证:是整个验证过程中最复杂的一个阶段,通过验证数据流和控制流的分析,确定程序语义是否正确,主要针对方法体的验证。如:方法中的类型转换是否正确,跳转指令是否正确等。
符号引用验证:这个动作在后面的解析过程中发生,主要是为了确保解析动作能正确执行。
3.准备
准备阶段是为类的静态变量分配内存并将其初始化为默认值,这些内存都将在方法区中进行分配。准备阶段不分配类中的实例变量的内存,实例变量将会在对象实例化时随着对象一起分配在Java堆中。
4.解析
该阶段主要完成符号引用到直接引用的转换动作。解析动作并不一定在初始化动作完成之前,也有可能在初始化之后。
5.初始化
初始化时类加载的最后一步,前面的类加载过程,除了在加载阶段用户应用程序可以通过自定义类加载器参与之外,其余动作完全由虚拟机主导和控制。到了初始化阶段,才真正开始执行类中定义的Java程序代码。
函数接口
只有一个抽象方法,就是函数式接口
Java中的函数式编程体现就是Lambda表达式。
所以函数式接口即可以适用于Lambda使用的接口
ArrayList和LinkedList的区别
1.ArrayList底层是实现了基于动态数组的数据结构,而LinkedList是基于双向链表的数据结构
2.对于随机访问get和set ArrayList要优于LinkedList,因为LinkedList要移动指针
3.LinkedList有序的,可以存储重复值和null值,
4.ArrayList是有序的,可以存储重复值和null值,
5.ArrayList扩容机制默认情况下新容量是原容量的扩容因子为1.5,初始容量为10。
6.LinkedList底层是双向链表,没有扩容机制
反射获取类加载器
Class<?> lei=类.class;
继承的概念
可以使得子类具有父类的属性和方法,还可以在子类中重新定义,以及追加属性和方法
Lambda表达式什么时候用
当我们需要对集合中的元素进行操作的时候,除了必需的添加、删除、获取外,最典型的就是集合遍历
1.每当我们需要对集合中的元素进行操作的时候,总是需要进行循环、循环、再循环。循环 是做事情的方式,而不是目的。每个需求都要循环一次,还要搞一个新集合来装数据,如果希望再次遍历,只能再使 用另一个循环从头开始 使用Stream流解决
2.减少冗余代码 ,提高开发效率
作用: 对集合进行非常复杂的查找、过滤、筛选等操作
操作方式 1.创建操作 2.中间操作 3.结束操作
注意:必须结束操作了 中间操作才会执行