Java——构造代码块优先于构造函数执行

构造代码块:

作用:给对象进行初始化。

对象一建立就运行,而且优先于构造函数执行。

构造代码块与构造函数的区别:

  • 构造代码块是给所有对象进行统一初始化,
  • 而构造函数是给对应的对象初始化。

构造代码快中定义的是不同对象共性的初始化内容。

//一旦创建对象,构造代码块先于构造函数执行
class Person
{
	private String name;
	private int age;
	
     //构造代码块
	{
		System.out.println("construction code..");
	}
	
	Person()
	{
		name = "Lisi";
		age = 20;
	}

	void speak()
	{
		System.out.println("name+" + name);
		System.out.println("age+" + age);
	}
	
}

public class PersonDemo
{
	public static void main(String[] args)
	{
		Person p = new Person();
		p.speak();
	}
}
/*
construction code..
name+Lisi
age+20
*/

 

//构造代码块先于构造函数执行,与构造代码块的位置无关
class Person
{
	private String name;
	private int age;
	
	Person()
	{
		name = "Lisi";
		age = 20;
	}

	//构造代码块
	{
		System.out.println("construction code..");
	}
	
	void speak()
	{
		System.out.println("name+" + name);
		System.out.println("age+" + age);
	}
	
}

public class PersonDemo
{
	public static void main(String[] args)
	{
		Person p = new Person();
		p.speak();
	}
}
/*
construction code..
name+Lisi
age+20
*/
//构造代码块中定义的是不同对象共性的初始化内容
class Person
{
	private String name;
	private int age;
	
	Person()
	{
		name = "Lisi";
		age = 20;
		System.out.println(name);
//		speak();
	}
	
	//构造代码块
	{
		speak();
	}
	
	Person(String namee)
	{
		name = namee;
		System.out.println(namee);
//		speak();
	}
	
	
	Person(String namee, int agee)
	{
		name = namee;
		age = agee;
		System.out.println(namee);
//		speak();
	}
	
	void speak() 
	{
		System.out.print("talk...");	
	}
	
}

public class PersonDemo
{
	public static void main(String[] args)
	{
		Person p1 = new Person();
		Person p2 = new Person("Zhangsan");
		Person p3 = new Person("Wangwu", 24);	
	}
}
/*
talk...Lisi
talk...Zhangsan
talk...Wangwu
*/

 

 

### Java 构造函数执行顺序解释 在 Java 中,构造函数执行遵循特定的顺序,这涉及到多个方面,包括静态代码块构造代码块以及继承关系中的构造函数调用。 #### 静态代码块与静态变量初始化 静态代码块和静态变量会在类加载到 JVM 时被执行一次,并且按照它们在源文件中出现的顺序依次执行[^1]。这意味着如果一个类中有多个静态代码块,则这些代码块会依照其定义的位置先后顺序执行。 #### 基础类与派生类之间的构造过程 对于存在继承关系的基础类(Base)及其派生类(Son),当创建一个新的 `Son` 对象时: - **先执行基础类(`Base`) 的构造逻辑** - 如果有显式的无参构造器则直接调用;如果有带参数的构造器而没有默认构造器的话,默认情况下编译器不会自动提供无参构造器。 - **接着是任何成员属性(如字段)在其声明处指定初始值表达式的求值** - **再之后才是当前类 (`Son`) 自身的构造体部分** 具体来说,在给定的例子中,当实例化 `Son` 类的对象时,程序输出将会显示如下序列[^2]: ```text base is called value is called son is called ``` 这段文字表明了基类 `Base` 的构造方法最先被触发,随后由于 `Son` 类内部定义了一个名为 `v` 的 `Value` 实例成员,因此紧接着就调用了该类型的构造方法来完成这个成员对象的构建工作,最后才轮到了 `Son` 类自己的构造方法得以执行并打印消息。 #### 复杂情况下的构造链路分析 更复杂的情况下——比如涉及多层继承结构或是跨不同包内的不同类型之间相互依赖的情形下——整个构造链条可能会变得更加错综复杂。然而无论如何变化,基本原则始终不变:总是优先处理最顶层祖先类的相关事项,逐步向下推进直至最终的目标类型完全建立起来为止[^3]。 另外需要注意的是,除了上述提到的内容外,还有可能遇到其他形式的初始化操作,例如通过匿名内部类的方式间接引入额外层次上的构造活动等特殊场景[^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值