一、非静态代码块

  1、声明格式

【修饰符】 class 类名 {
{
非静态代码块
}
}

  2、非静态代码块中的代码执行时机

    (1)在"每次"创建对象的时候执行

    (2)比构造方法早

    Demo:

 class MyClass{
private String str; public MyClass(){
System.out.println("无参构造2");
}
public MyClass(String str){
this.str = str;
System.out.println("有参构造3");
} {
System.out.println("非静态代码块1");
}
}

    运行结果:先执行非静态代码中输出"非静态代码块1",然后执行无参构造方法输出"无参构造2"。

  3、实例初始化过程

    初始化过程:创建对象时,为对象进行初始化的操作

    执行顺序:

① 为成员变量显示赋值

② 执行非静态代码块

③ 执行构造器

    图解:

    Java 编译器其实,会把这三个部分的代码,合成一个叫做 <init>(【形参列表】) 实例初始化方法。

    即编译后的 .class 字节码文件中,是没有构造方法这个概念的。

    <init>(【形参列表】) 实例初始化方法的代码就是由三个部分组成:

① 成员变量显示赋值的代码

② 非静态代码中的代码

③ 构造器中的代码

    注意:

      1、其中的 ① 和 ② 按顺序执行,而 ③ 一定是它们当中的最后执行的。

      2、有几个构造器,就会有几个实例初始化方法。那么当创建对象的时候,调用对应的构造器时,其实执行的是对应的实例初始化方法 <init>(【...】)

二、继承中的非静态代码块

  1、继承案例

    先来看一个没有非静态的代码块的继承关系:

    Demo:

 public class TestInit {
public static void main(String[] args) {
Father f = new Father();
//执行父类的无参构造 Son s = new Son();
//先执行父类的无参构造,再执行子类的无参构造 Son s2 = new Son("HelloWorld");
//先执行父类的无参构造,再执行子类的有参构造1 Son s3 = new Son("Java", 10);
// 先执行父类的无参构造,再执行子类的有参构造1,然后再执行子类的有参构造2 }
}
//父类
class Father{
public Father(){
System.out.println("父类的无参构造");
}
}
// 子类
class Son extends Father{
private String str;
private int num; public Son(){
//隐含了super(); 子类的构造器中一定会调用父类的构造器,默认调用父类的无参构造
System.out.println("子类的无参构造");
} public Son(String str){
//隐含了super()
this.str = str;
System.out.println("子类的有参构造1");
} public Son(String str,int num){
this(str); //这里有this就不会有super了,然后调用本类中的构造方法
this.num = num;
System.out.println("子类的有参构造2");
}
}

  2、含有非静态代码块的继承关系

    (1)先执行父类的实例初始化方法

      它由三部分组成:

① 成员变量的显示赋值

② 非静态代码块

③ 构造方法

    (2)再执行子类的实例初始化方法

      它由三部分组成:

① 成员变量的显示赋值

② 非静态代码块

③ 构造方法

    注意:

    ① super() 或 super(实参列表) 之前说的是调用父类的构造器,其实是调用父类对应的实例初始化方法

    ② super() 或 super(实参列表) 之前说的是在子类构造器的首行,其实是在子类实例初始化方法的首行,所以会先完成父类的初始化,再进行子类的初始化。

    Demo:

 public class TestInit {
public static void main(String[] args) {
Fu f = new Fu(); //
System.out.println("==========");
Zi z = new Zi(); //
}
} class Fu{
private String strFu = assignFu();
{
System.out.println("(1)父类的非静态代码块");
}
public Fu(){
System.out.println("(2)父类的无参构造");
}
public String assignFu(){
System.out.println("(3)父类的assignFu()");
return "fu";
}
}
class Zi extends Fu{
private String strZi = assignZi();
{
System.out.println("(4)子类的非静态代码块");
}
public Zi(){
//super() ==>调用父类的实例初始化方法,而且它在子类实例初始化方法的首行
System.out.println("(5)子类的无参构造");
} public String assignZi(){
System.out.println("(6)子类的assignZi()");
return "zi";
}
}

   运行结果:

     

      图解:

  

  3、含有非静态代码块的重写继承关系

    Demo:

 public class TestInit {
public static void main(String[] args) {
Ba b = new Ba(); //
System.out.println("============");
Er r = new Er(); //612645,因为子类重写了assign() }
}
class Ba{
private String str = assign();
{
System.out.println("(1)父类的非静态代码块");
}
public Ba(){
System.out.println("(2)父类的无参构造");
}
public String assign(){
System.out.println("(3)父类的assign()");
return "ba";
}
}
class Er extends Ba{
private String str = assign();
{
System.out.println("(4)子类的非静态代码块");
}
public Er(){
//super() ==>调用父类的实例初始化方法,而且它在子类实例初始化方法的首行
System.out.println("(5)子类的无参构造");
} public String assign(){
System.out.println("(6)子类的assign()");
return "er";
}
}

  运行结果:

  

  图解:

  注意:this在构造器中,在实例化初始化方法中,代表的是正在创建的对象,当创建子类对象时,因为子类重写的 assign(),那么执行是子类重写的 assign() 方法。

  

Java 面向对象—非静态代码块的更多相关文章

  1. java 子类、父类中静态代码块、字段,非静态代码块、字段以及构造函数的初始化顺序和次数

    一个类中的数据初始化顺序是面试官非常喜欢出的面试题之一,本文用一个实例来介绍java中子类.父类中静态代码块.字段,非静态代码块.字段以及构造函数的执行顺序和次数. 一.包结构

  2. JAVA程序执行顺序(静态代码块》非静态代码块》静态方法》构造函数)

    总结:静态代码块总是最先执行. 非静态代码块跟非静态方法一样,跟对象有关.只不过非静态代码块在构造函数之前执行. 父类非静态代码块.构造函数执行完毕后(相当于父类对象初始化完成), 才开始执行子类的非 ...

  3. java中静态代码块,非静态代码块,构造函数

    关于静态代码块 静态代码块的写法: static { System.out.println("我是静态代码块"); } 静态代码块的特点: 1.执行优先级高于非静态的初始化块,它会 ...

  4. Java静态代码块与非静态代码块

    静态代码块,格式是 static{ },随着类的加载而加载,且只执行一次. 在程序中,执行的优先级最高. 非静态代码块,格式是{ },在创建对象的时候运行(即new一个对象的时候),每创建一次对象就执 ...

  5. Java非静态代码块和静态代码块

    类中存在两种特殊的代码块,即非静态代码块和静态代码块,前者是直接由 { } 括起来的代码,而后者是由 static{ } 括起来的代码. 非静态代码块在类初始化创建实例时,将会被提取到类的构造器中执行 ...

  6. Java中静态变量、静态代码块、非静态代码块以及静态方法的加载顺序

    在研究单例设计模式的时候,用到了静态变量和静态方法的内容,出于兴趣,这里简单了解一下这四个模块在类初始化的时候的加载顺序. 经过研究发现,它们的加载顺序为: 1.非静态代码块 2.静态变量或者静态代码 ...

  7. 浅谈Java中静态代码块和非静态代码块

    静态代码块: static{} 执行优先级高于非静态的初始化块,它会在类初始化(类初始化这个问题改天再详细讨论)的时候执行一次,执行完成便销毁,它仅能初始化类变量,即static修饰的数据成员. 非静 ...

  8. Java子父类间静态代码块、非静态代码块、构造方法的执行顺序

    子类A继承父类B,A a=new A(); 正确的执行顺序是:父类B静态代码块->子类A静态代码块->父类B非静态代码块->父类B构造函数->子类A非静态代码块->子类A ...

  9. 静态代码块&非静态代码块&构造函数

    总结:静态代码块总是最先执行.非静态代码块跟非静态方法一样,跟对象有关.只不过非静态代码块在构造函数之前执行.父类非静态代码块.构造函数执行完毕后(相当于父类对象初始化完成), 才开始执行子类的非静态 ...

随机推荐

  1. 28 让树莓派开机“说”出自己的IP地址

    http://shumeipai.nxez.com/2019/02/02/analogue-audio-redux.html 树莓派音频口底噪消除的方法

  2. Amoeba读写分离(MySQL)

    实验操作环境: centos服务器  三台机器 role: 192.168.189.129  master-主 192.168.189.130  master-从 192.168.189.131    ...

  3. three.js 添加环境光

    var ambient = new THREE.AmbientLight(0xffffff);//环境光 scene.add(ambient);

  4. hive基础知识四

    1. hive表的数据压缩 1.1 数据的压缩说明 压缩模式评价 可使用以下三种标准对压缩方式进行评价 1.压缩比:压缩比越高,压缩后文件越小,所以压缩比越高越好 2.压缩时间:越快越好 3.已经压缩 ...

  5. 【Kubernetes学习之四】Kubernetes可视化管理

    环境 centos 7 k8s-master 192.168.118.106 k8s-node01 192.168.118.107 k8s-node01 192.168.118.108 之前使用ku8 ...

  6. [原创]UnLua Emmylua UE4开发环境搭建

    前言 公司开发的第二个虚幻4项目已经上线了,慢慢趋于稳定.回想起开荒的日子,历历在目.从引擎脚本的选择,各工具(导表,协议生成...)的重构.开发, 引擎扩展(多骨骼支持,Notify扩展,技能编辑器 ...

  7. Nginx 整合 Lua 实现动态生成缩略图

    原文地址:Nginx 整合 Lua 实现动态生成缩略图 博客地址:http://www.extlight.com 一.前提 最近在开发一个项目,涉及到缩略图的功能,常见的生成缩略图的方案有以下几个: ...

  8. asbDio (asbDio.dll)

    using System;using System.Collections.Generic;using System.Text;using System.Runtime.InteropServices ...

  9. spring boot 从开发到部署上线(简明版)

    我们组有一个优良传统--借鉴于"冰桶挑战赛"的形式,采取点名的方式,促进团队成员每天利用一小段时间,不断的完善团队 wiki 的小游戏. 但有时候忙于业务,可能会忘记,所以我写了一 ...

  10. 使用 Jest 和 Supertest 进行接口端点测试

    如何创建测试是一件困难的事.网络上有许多关于测试的文章,却从来不告诉你他们是如何开始创建测试的. 所以,今天我将分享我在实际工作中是如何从头开始创建测试的.希望能够对你提供一些灵感. 目录: 使用 E ...