1、在类实例被初始化的时候执行 2、在类的静态成员被调用的时候执行 3、静态构造函数只会被执行一次,代码如下: static class Program { static void...TestIns = new Test(); } public static Test TestIns; public int Flag=0; } 说明静态构造函数只执行了一次
出现继承时: 1.初始化父类的静态变量、静态代码块,初始化的顺序按照出现的顺序。 2.初始化子类的静态变量,静态代码块。 3.初始化父类的成员变量。 4.执行父类的构造函数。...父类$$构造函数$$; n=100 m=50 父类%%静态块%%调用; m=100 父类**构造块**调用;n=10 m=200 父类$$构造函数$$;...n=100 m=210 【 子类 】@@ 静态块 @@调用; m=212 父类**构造块**调用;n=10 m=424 父类$$构造函数$$; n=100...**构造块**调用;n=10 m=40 父类$$构造函数$$; n=100 m=50 父类%%静态块%%调用; m=100 父类**构造块**调用;n=10 m=200 父类$$构造函数$...%%静态块%%调用; m=10 父类**构造块**调用;n=10 m=20 父类$$构造函数$$; n=100 m=30 【 子类 】@@ 静态块 @@调用; m=32 父类**构造块
String naem; private Date date; //构造函数 public User(){ System.out.println("构造函数......"); } //构造代码块 { System.out.println("构造代码块..."); } //静态代码块 static{...,而且优先于构造函数执行。...构造函数的作用: 给对象进行初始化,对象一建立就运行。 构造函数和构造代码块的区别: 构造代码块是给所有对象进行统一初始化;而构造函数是给对应的对象初始化。...构造代码块中定义的是不同对象共性的初始化内容。 静态代码块的作用: 随着类的加载而执行,只执行一次,并优先于主函数,用于给类进行初始化。
具体说,静态代码块是由类调用的。...类调用时,先执行静态代码块,然后才执行主函数的,总的来说,静态代码块是和类一起的,优先级最高,类加载的同时,静态代码块同时也执行,但只执行一次,所以作用一般是用来加载一些配置代码,或者加载某些文件配置。...构造函数 构造函数的作用是用于给对象进行初始化,对象一建立,就会调用与之相应的构造函数,也就是说,不建立对象,构造函数时不会运行的。 构造代码块 构造代码块的作用同样是给对象进行初始化。...构造函数和构造代码块的区别: 构造代码块与构造函数的区别是:构造代码块是给所有对象进行统一初始化,而构造函数是给对应的对象初始化,因为构造函数是可以多个的,运行哪个构造函数就会建立什么样的对象,但无论建立哪个对象...也就是说,构造代码块中定义的是不同对象共性的初始化内容。 运行结果: 可以看出来,静态代码块只执行一次,而每次创建对象都会调用共同的构造代码块,而构造函数也只在创建对象时执行该对象的构造函数。
System.out.println("-------第2次实例化-------"); new C(); } } class A { public A(){ System.out.println("构造静态属性.../** * 静态代码块先于构造器执行 普通块先于构造块 只执行一次 * 凡是静态的与对象无关,先于对象存在的; 凡是静态的都是共享的 */ B b = new B(); static...public C(){ System.out.println("构造函数C"); } } 运行结果: -------第1次实例化------- 父类的静态属性E 构造静态属性A 静态代码块...父类的普通属性F 构造父类D 构造普通属性B 普通代码块 构造函数C -------第2次实例化------- 父类的普通属性F 构造父类D 构造普通属性B 普通代码块 构造函数...C 结论(实例化顺序): 父类静态的属性 父类静态的代码块 子类静态的属性 子类静态的代码块 父类普通属性 父类普通代码块 父类构造函数 子类普通属性 子类普通代码块 子类构造函数 静态的东西只在第一次实例化的时候执行
构造代码块,和构造函数都存在于一个类中,只不过,他们执行的先后顺序和执行的次数不同。...构造函数:构造函数的命名必须和类名完全相同,它没有返回值,也不能用void来修饰。 执行顺序优先级:静态块>main()>构造块>构造方法。...加载的时候,将静态成员变量(类变量),构造代码块,静态代码块以及静态方法加载到方法区的静态部分,非静态方法以及构造方法加载到方法区的非静态部分。...接着开始在堆内存中对实例变量进行默认初始化, 然后执行构造代码块,对object进行对应的构造代码块的初始化, 最后进行构造函数的初始化,对object进行对应的构造函数初始化。...作用分析 静态代码块用于给类初始化,类加载的时候就会被执行; 构造代码块用于给对应对象初始化,只要创建对象就会被执行,而且执行的顺序优先于构造函数; 构造函数用于给对应对象初始化,只要创建对象,就会选择相应的构造函数进行初始化
调用的时候,只允许一个线程执行进入静态构造函数,换句话说是一个类型的静态构造函数不会重复被多个线程执行,只会被执行一次。...这就意味着无论是静态构造函数还是实例构造函数,都是只能被一个线程执行。...相当于进入静态构造函数时设置了一个锁对象,只有一个线程能进入调用静态构造函数,其他线程只能等待静态构造函数执行完成才能继续 多线程在碰到某个类型的静态构造函数时,就和碰到竞态资源一样,也相当于碰到一个锁...如此能很大解决因为静态构造函数的时机问题导致的问题,无论什么时候碰到静态构造函数,如果静态构造函数只是做非常简单的和无依赖的逻辑,那自然是没有什么问题 而如果是如本文要聊的,在类型的静态构造函数里面,碰到了锁...,静态构造函数是在类型第一次碰到时被触发,也就是开发者是无法确定静态构造函数合适被调用的。
3.构造函数 Java使用与类同名的方法(有参或无参){//Code...}的格式代表构造函数。...%d个执行\n", ++i); } } 控制输出: 静态代码块代码块第1个执行 执行main方法 构造代码块第2个执行 构造函数第3个执行 普通代码块第4个执行 执行顺序: 静态代码块->...子类的静态代码块第3个执行 父类的父类的构造函数第4个执行 父类的构造函数第5个执行 子类的构造函数第6个执行 根据Demo-2代码实验可知,涉及继承的代码块执行顺序是这样的: 父类的静态方法->...子类的静态方法->父类的构造代码块->父类的构造函数->子类的构造代码块->子类的构造函数 相关原理以及解释: 因为static修饰的代码在类加载的时候就进行执行,而类加载是先于对象创建的,所以子类和父类的静态方法要首先执行...所以有“父类的构造代码块->父类的构造函数->子类的构造代码块->子类的构造函数”如此的执行顺序。
在Java中,静态代码块、构造代码块、构造函数、普通代码块的执行顺序是一个笔试的考点,通过这篇文章希望大家能彻底了解它们之间的执行顺序。...("静态代码块"); } } ②、执行时机 静态代码块在类被加载的时候就运行了,而且只运行一次,并且优先于各种代码块以及构造函数。...("静态代码块"); } { System.out.println("构造代码块"); } } ②、执行时机 构造代码块在创建对象时被调用,每次创建对象都会调用一次,但是优先于构造函数执行...但是反过来,构造函数则不一定每个对象建立时都执行(多个构造函数情况下,建立对象时传入的参数不同则初始化使用对应的构造函数)。 ...; 4.当定义一个类的时候,通常情况下都会显示该类的构造函数,并在函数中指定初始化的工作也可省略,不过Java编译器会提供一个默认的构造函数.此默认构造函数是不带参数的。
不允许使用 Java 静态构造函数,但是为什么呢?在深入探讨不允许使用静态构造函数的原因之前,让我们看看如果要使 构造函数静态化 会发生什么。...[zhtwu6wcpq.png] 静态属于类,构造函数属于对象 我们知道静态方法,静态块或变量属于该类。而构造函数属于该对象,并在使用 new 运算符创建实例时调用。...由于构造函数不是类属性,因此有理由认为它不能是静态的。 静态块 / 方法无法访问非静态变量 我们知道静态方法不能访问非静态变量。静态块也是如此。 现在,构造函数的主要目的是初始化对象变量。...因此,如果我们将构造函数设置为静态,则无法初始化对象变量。这将破坏使用创建对象的构造函数的全部目的。因此,使构造函数为非静态是合理的。 注意,我们不能this在静态方法中使用引用对象变量。...我们可以使用静态块以及构造函数本身来初始化静态变量。
主要探讨一下关于静态代码块,非静态代码块,构造函数的执行顺序。 如有错误,欢迎指出。 首先: 静态成员变量和静态代码块的优先级是一样的,先定义的先执行。...在创建一个对象的时候会执行非静态代码块和构造函数 再者是执行顺序: /* * *(1)父类静态成员和静态初始化块,按在代码中出现的顺序依次执行。...* *(2)子类静态成员和静态初始化块,按在代码中出现的顺序依次执行。 * *(3)父类实例成员和实例初始化块,按在代码中出现的顺序依次执行。 * *(4)执行父类构造方法。...* *(6)执行子类构造方法。...2.在创建一个对象的时候会执行非静态代码块和构造函数。
C++构造函数的作用 C++提供了构造函数来处理对象的初始化,构造函数是一 种特殊的成员函数,与其他成员函数不同,不需要程序员来调用它,而是在建立对象时自动执行。...构造函数的名字必须与类名同名,而不能由程序员任意命 ,以便编译系统能识别它并把它作为构造函数处理,构造函数不具有任何类型,不返回任何值,它的功能是由程序员定义,程序员根据初始化的要求设计函数体和函数参数...关于构造函数,以下5点需要读者注意: 在类对象进入其作用域时调用构造函数。 构造函数没有返回值,不需要在定义构造函数时声明类型。 构造函数不需要程序员调用,也不能被程序员调用。...在构造函数的函数体中不仅可以对数据成员赋初值,而且可以包含其他语句。...如果用户自己没有定义构造函数,则C++编译系统会自动生成一个构造函数,只是这个构造函数的函数体是空的,也没有参数,不执行初始化操作。
2019.05.30问题 题目分类 继承——静态块、构造块、构造函数 题目 public class Test { public static void main
在 .NET 代码质量分析器中,该规则已合并到规则 CA1052:静态容器类型应为 Static 或 NotInheritable 中。...原因 公共或嵌套公共类型只声明了静态成员,但具有默认构造函数。 规则说明 由于调用静态成员不需要类型的实例,因此没必要使用默认构造函数。...另外,由于类型不具有非静态成员,因此创建实例不提供对任何类型成员的访问。 如何解决冲突 若要解决此规则的冲突,请删除默认构造函数。 何时禁止显示警告 不禁止显示此规则发出的警告。...如果存在默认构造函数,则表明该类型不是静态类型。
一、默认构造函数 C++ 类中 2 种特殊的构造函数 , 分别是 : 默认无参构造函数 : 如果 C++ 类中 没有定义构造函数 , C++ 编译器会自动为该类提供一个 " 默认的无参构造函数 " ,...; 1、默认无参构造函数 如果 C++ 类中 没有定义构造函数 , C++ 编译器会自动为该类提供一个 " 默认的无参构造函数 " , 函数体为空 , 不做任何操作 ; 没有定义构造函数 : 如果...没有为 C++ 类定义 构造函数 , C++ 编译器 将自动为该类 生成一个默认的无参构造函数 ; 定义了构造函数 : 如果为 C++ 类 定义了其他类型的构造函数 ( 有参构造函数 / 无参构造函数...obj; // 调用默认无参构造函数 MyClass obj2 = obj; // 调用默认拷贝构造函数 二、构造函数调用规则 ---- 1、构造函数规则说明 构造函数调用规则 : 提供 默认无参构造函数...定义了 非拷贝构造函数 , 如 : 有参构造函数 / 无参构造函数 , C++ 编译器 不会提供 默认的无参构造函数 , 但是 会提供 默认的 拷贝构造函数 ; 默认的 拷贝构造函数 只能进行 成员变量的
主构造函数 II . 主构造函数声明属性 III . init 初始化代码块 IV . 主构造函数参数 和 成员变量访问方式 V . 主构造函数 可见性 设置 VI ....次构造函数 ( 常用情况 ) VII . 次构造函数 ( 没有主构造函数 ) VIII . 构造函数 代码执行顺序 IX . 调用 主构造函数 / 次构造函数 创建类实例对象 I ....主构造函数 ---- 1 . 构造函数个数 : Kotlin 类定义时需要指定主构造函数 , 还可以指定 0 ~ 多个次构造函数 ; 2 ....主构造函数定义 : 主构造函数与类定义在一起 , 构造函数定义在类名后 , 格式为 constructor( 构造函数参数列表 ) ; 3 ....次构造函数 ( 没有主构造函数 ) ---- 如果类没有主构造函数 , 那么可以直接声明 次构造函数 , 不同委托给主构造函数 ; class Person { constructor ( 次构造函数参数列表
构造函数 在 JavaScript 中,用 new 关键字来调用的函数,称为构造函数。构造函数首字母一般大写(规范)。...之所以有构造函数与普通函数之分,主要从功能上进行区别的,构造函数的主要 功能为 初始化对象,特点是和new 一起使用。new就是在创建对象,从无到有,构造函数就是在为初始化的对象添加属性和方法。...以上就是构造函数的整个执行过程。 3、用new和不用new调用构造函数,有什么区别? 1、用new调用构造函数,函数内部会发生如下变化: 创建一个this变量,该变量指向一个空对象。...4、构造函数的返回值 构造函数执行过程的最后一步是默认返回 this 。言外之意,构造函数的返回值还有其它情况。 没有手动添加返回值,默认返回 this。...6、 构造函数和普通函数的区别 1、构造函数也是一个普通函数,创建方式和普通函数一样,但构造函数习惯上首字母大写。 2、调用方式不一样。
一、构造函数分类 1、构造函数分类简介 C++ 构造函数可以分为以下几类 : 无参构造函数 : 最简单也是默认的构造函数 , 函数没有参数 , 如果创建一个对象 , 没有传入参数 , 调用的就是该类型的...构造函数 ; 有参构造函数 : 带参数的 构造函数 , 创建 实例对象 时 , 为成员变量提供初始值 ; 拷贝构造函数 : 拷贝现有 实例对象 , 并以此拷贝的副本为数据 创建一个新的 实例对象 ,...<< "name : " << s1.m_name << " , age : " << s1.m_age << endl; 有参构造函数 有参构造函数 : 可以将 为 成员变量 赋值的数据放在 构造函数...; 拷贝构造函数 拷贝构造函数 : 拷贝构造函数 也是 有参构造函数 中的一种 , 传入的是 相同类型的 常量引用 , 该引用指向的内容在函数内不可修改 ; 在 " 拷贝构造函数 " 中 , 主要读取..." << endl; } 二、代码示例 - 三种类型构造函数定义与调用 ---- 在下面的代码中 , 分别在 Student 类中定义了 无参构造函数 有参构造函数 拷贝构造函数 分别调用了上述三种类型的
如下所示的两段IL代码分别来源于Foo和Bar,我们可以看到虽然Foo类中没有显式定义静态构造函数,但是编译器会创建一个默认的静态构造函数,针对静态字段的初始化就放在这里。...两个类型之间的差异并没有体现在静态构造函数上,而是在于:没有显式定义静态构造函数的Foo类型上具有一个beforefieldinit标记。...从Foo和Bar的IL代码可以看出,针对它们静态字段的初始化都放在静态构造函数中。...,所以我们自行定义的专门用来初始化静态字段的静态构造函数是完全没有必要的。...四、关于“All-Zero”结构体 如果我们在一个结构体中显式定义了一个静态构造函数,当我们调用其构造函数之前,静态构造函数会自动执行。
一、静态成员函数简介 1、静态成员函数概念 静态成员函数归属 : 在 C++ 类中 , 静态成员函数 是一种 特殊的函数 , 该函数属于类 , 而不是属于 类实例对象 ; 静态成员函数调用不依赖于对象...调用 静态成员函数 s.fun(); 4、静态成员函数只能访问静态成员 静态成员函数内容要求 : 静态成员函数 只能访问 静态成员变量 其他静态成员函数 静态成员函数 不能访问 非静态成员变量 或 非静态成员函数...调用 静态成员函数 s.fun(); 代码示例 : #include "iostream" using namespace std; class Student { public: // 带参构造函数...Student(int age, int height) { m_age = age; m_height = height; cout << "执行 Student 的构造函数" <<...number = 1 执行 Student 的构造函数 s.number = 2 静态成员函数被调用 : number = 2 静态成员函数被调用 : number = 2 请按任意键继续. . .
领取专属 10元无门槛券
手把手带您无忧上云