1、遵照上边,报名地方

EF主题技能分析介绍

类的加载进度

  1. 数码上下文(共享对象与实例对象的抉择)
  2. 电动初阶化(Initializer开始化的两种方法)
  3. 多少迁移(Migrations怎么着使用及其关键效能)
  4. 实体关系映射(一对1,一对多,多对多)
  5. 延时加载和include立刻加载
  6. 写SaveChanges解决出现冲突的难点
  7. DbCommandInterceptor达成读写分离
  8. 实业主键泛型化的实际意义

类公事加载的次第

壹、先加载施行父类的静态变量及静态开端化块(实行先后顺序按排列的先后顺序)
2、再加载试行本类的静态变量及静态初阶化块

只要类未有被灭绝,静态变量及静态开首化块只会推行三遍,后续再对该类举办别的操作也不会再进行那七个步骤。

 

类实例制程

唯有在调用new方法时才会创立类的实例
壹、遵照地点类公事加载的次第(类已被加载则跳过此步)
2、父类的非静态变量及非静态初叶化块
3、父类的构造方法
四、本类的非静态变量及非静态初叶化块
伍、本类的构造方法
四、类实例销毁时候,首先销毁子类部分,再销毁父类部分

报名地方:http://www.genshuixue.com/teacher/classCourseDetail/161121909106

静态方法和非静态方法都是颓败调用

即系统不会活动调用执行。所以用户并未有调用时都不实践,首要分歧在于静态方法能够平素用类名直接调用(实例化对象也足以),而非静态方法只可以先实例化对象后才干调用。

连锁概念

static关键字:

是二个修饰符,用于修饰成员(成员变量和成员函数)

被修饰后的分子具备以下特征:

乘机类的加载而加载(类One plus载,静态数据就及时在内部存款和储蓄器中加载空间)

趁着类的消灭而消失,表明它的生命周期最长

事先于对象存在(对象消失了,static还在)

静态先存在,对象后存在

被抱有指标所共享

节本省部存款和储蓄器空间

当成员被静态修饰后,除了能够被对象调用外,还足以直接被类名调用

写法:类名.静态成员

应用注意

静态方法只好访问静态成员(方法和变量)

非静态方法既能够访问静态也得以访问非静态

静态方法中不可能写this,super关键字

因为静态优先于对象存在,所以静态方法中不可能出现this

主函数是静态的

public static void main(String[] args){}

什么时候使用静态?

要从两上边起始:因为静态修饰的始末有成员变量和函数。

哪一天定义静态变量(类变量)

当对象中出现共享数据时,该数额被静态所修饰。对象中的特有数量要定义成非静态存在于堆内部存款和储蓄器中。

什么时候定义静态函数

当效用内部尚未访问到非静态数据(对象特有数量),该意义能够定义成静态。

静态利弊:

利:
一、对指标的共享数据单独空间的储存,节省空间。完全没须要各样对象都存储1份。
二、能够直接被类名调用
弊:
一、生命周期过长
二、访问出现局限性(只好访问静态)

内部存款和储蓄器结构

Java程序在运转时,须要在内部存款和储蓄器中的分配空间。为了巩固运算效能,有对空间拓展了分裂区域的细分,因为每一片区域都有特定的拍卖多少格局和内存管理形式。

栈内存

  • 用来存款和储蓄部分变量
  • 当数码利用完,所占空间会自动释放

堆内存

  • 数组和对象(实体),通过new建立的实例都存放在堆内部存款和储蓄器中(成员变量乘机对象的确立而树立,存在于对象所在的堆内部存款和储蓄器中)
  • 每三个实体都有内部存储器地址值(变量通过地点引用)
  • 实业中的变量都有暗许起先化值
  • 实业不再被使用,会在不明确的小时内被垃圾回收器回收(污源回收机制)

方法区,当地点法区,寄存器

验证

加载顺序 父类静态变量=1
【父类调用父类静态方法】 Parent.pStaticMethod();
父类静态初始化块一 2
父类静态初始化块二 3
父类静态方法 4
【子类调用子类静态方法】 Child.cStaticMethod();
子类静态初始化块一 5
子类静态初始化块二 6
子类静态方法 7
【子类实例化】 Child c=new Child();
父类非静态初始化块一 8
父类非静态初始化块二 9
父类构造方法 10
子类非静态初始化块一 11
子类非静态初始化块二 12
子类构造方法 13
【父类实例化子类对象】 Parent p=new Child();
父类非静态初始化块一 14
父类非静态初始化块二 15
父类构造方法 16
子类非静态初始化块一 17
子类非静态初始化块二 18
子类构造方法 19
加载顺序 父类静态变量=1
【子类实例化】 Child c=new Child();
父类静态初始化块一 2
父类静态初始化块二 3
子类静态初始化块一 4
子类静态初始化块二 5
父类非静态初始化块一 6
父类非静态初始化块二 7
父类构造方法 8
子类非静态初始化块一 9
子类非静态初始化块二 10
子类构造方法 11
【父类实例化子类对象】 Parent p=new Child();
父类非静态初始化块一 12
父类非静态初始化块二 13
父类构造方法 14
子类非静态初始化块一 15
子类非静态初始化块二 16
子类构造方法 17
【父类调用父类静态方法】 Parent.pStaticMethod();
父类静态方法 18
【子类调用子类静态方法】 Child.cStaticMethod();
子类静态方法 19
public class ClassTest {    
    public static void main (String args[]) {
        System.out.println("【子类实例化】|Child c=new Child();");     
        Child c=new Child();
        System.out.println("【父类实例化子类对象】|Parent p=new Child();");        
        Parent p=new Child();
        System.out.println("【父类调用父类静态方法】|Parent.pStaticMethod();");
        Parent.pStaticMethod();
        System.out.println("【子类调用子类静态方法】|Child.cStaticMethod();");
        Child.cStaticMethod();
    }
}

public class ClassTest2 {   
    public static void main (String args[]) {
        System.out.println("【父类调用父类静态方法】|Parent.pStaticMethod();");
        Parent.pStaticMethod();
        System.out.println("【子类调用子类静态方法】|Child.cStaticMethod();");
        Child.cStaticMethod();
        System.out.println("【子类实例化】|Child c=new Child();");     
        Child c=new Child();
        System.out.println("【父类实例化子类对象】|Parent p=new Child();");        
        Parent p=new Child();
    }
}

public class Parent {
    // 父类静态变量
    static int m = 1;   
    // 父类非静态变量
    int n = 1;

    // 静态语句块1
    static {
        m++;
        // j++; 父类非静态变量不能在静态语句块中使用
        System.out.println("父类静态初始化块一|" + m);
    }
    // 静态语句块2
    static {
        m++;
        System.out.println("父类静态初始化块二|" + m);
    }

    // 构造函数
    public Parent() {
        m++;
        n++;
        System.out.println("父类构造方法|" + m + "|" + n);
    }

    // 非静态语句块
    {
        m++;
        n++;
        System.out.println("父类非静态初始化块一|" + m + "|" + n);
    }

    // 非静态语句块
    {
        m++;
        n++;
        System.out.println("父类非静态初始化块二|" + m + "|" + n);
    }

    // 非静态方法
    public void pMethod() {
        m++;
        n++;
        System.out.println("父类非静态方法|" + m + "|" + n);
        return;
    }

    // 静态方法
    public static void pStaticMethod() {
        m++;
//      j++; 父类非静态变量不能在静态方法中使用
        System.out.println("父类静态方法|" + m);
        return;
    }

    @Override
    protected void finalize() throws Throwable {
        super.finalize();
        System.out.println("销毁父类|");
    }
}

public class Child extends Parent {
    // 静态变量
    static int i = 1;
    // 非静态变量
    int j = 1;

    // 静态语句块1
    static {
        m++;
        i++;
        // j++; 非静态变量不能在静态语句块中使用
        System.out.println("子类静态初始化块一 " + "|" + m + "||" + i);
    }
    // 静态语句块2
    static {
        m++;
        i++;
        System.out.println("子类静态初始化块二 " + "|" + m + "||" + i);
    }

    // 构造函数
    public Child() {
        m++;
        n++;
        i++;
        j++;
        System.out.println("子类构造方法 " + "|" + m + "|" + n + "|" + i + "|" + j);
    }

    // 非静态语句块
    {
        m++;
        n++;
        i++;
        j++;
        System.out.println("子类非静态初始化块一" + "|" + m + "|" + n + "|" + i + "|" + j);
    }
    // 非静态语句块
    {
        m++;
        n++;
        i++;
        j++;
        System.out.println("子类非静态初始化块二" + "|" + m + "|" + n + "|" + i + "|" + j);
    }

    // 非静态方法
    public void pMethod() {
        m++;
        n++;
        i++;
        j++;
        System.out.println("子类继承非静态方法" + "|" + m + "|" + n + "|" + i + "|" + j);
        return;
    }

    // 静态方法
    public static void pStaticMethod() {// 静态方法不能被继承
        m++;
        i++;
        // j++; 非静态变量不能在静态方法中使用
        return;
    }

    // 非静态方法
    public void cMethod() {
        m++;
        n++;
        i++;
        j++;
        System.out.println("子类非静态方法" + "|" + m + "|" + n + "|" + i + "|" + j);
        return;
    }

    // 静态方法
    public static void cStaticMethod() {
        m++;
        i++;
        // j++; 非静态变量不能在静态方法中使用
        System.out.println("子类静态方法 " + "|" + m + "||" + i);
        return;
    }

    @Override
    protected void finalize() throws Throwable {
        super.finalize();
        System.out.println("销毁子类|");
    }
}

引用:
类的加载顺序
Java中类的加载顺序剖析(常用于面试题)

相关文章