构造代码块:

描述Teacher对象/实体:

package android.java.oop06;

public class Teacher {

    private int id = 007;
private String name = "零零发";
private int age = 98;
private float height = 1.78F; /**
* 静态代码块:当前Teacher类,被加载进内存时 就会执行此静态代码块里面的主体{}
* 可以说是最先执行的,可以在这里做一些静态成员的初始化工作
*/
static {
System.out.println("静态代码块:当前Teacher类,被加载进内存时 就会执行此静态代码块里面的主体{}");
System.out.println("");
} /**
* 构造代码块:每一个构造函数,的第三行执行者 就是构造代码块;
* 构造代码块可以给成员变量字段进行初始化工作等;
*/
{
System.out.println("构造代码块 被所有构造方法的第三行执行者 执行了...");
showAllValue();
} /**
* 构造函数是专门给对象实例化用的:
* new Teacher(); ---> public Teacher(){}
* ...
*
* 就算不写构造函数 也会默认有一个无参构造函数;
* 一旦写了 无参构造函数/有参构造函数 后 默认隐式的那个构造函数就不见了
*/
public Teacher() {
System.out.println("无参构造函数,我被new Teacher()实例化了");
showAllValue();
return; // 此方法默认就有这样一句return;隐式的,是可以让方法弹栈/结束;
} /**
* 构造函数是专门给对象实例化用的:
* new Student(9); ---> public Student(int value){}
* ...
*
* 就算不写构造函数 也会默认有一个无参构造函数;
* 一旦写了 无参构造函数/有参构造函数 后 默认隐式的那个构造函数就不见了
*/
public Teacher(int value) {
System.out.println("有参构造函数,我被new Teacher(int类型的值)实例化了 value:" + value);
showAllValue();
return; // 此方法默认就有这样一句return;隐式的,是可以让方法弹栈/结束;
} /**
* 构造函数是专门给对象实例化用的:
* new Student("刘俊", true); ---> public Student(String value1, boolean value2){}
* ...
*
* 就算不写构造函数 也会默认有一个无参构造函数;
* 一旦写了 无参构造函数/有参构造函数 后 默认隐式的那个构造函数就不见了
*/
public Teacher(String name, boolean isSuccess) {
System.out.println("无参构造函数,我被new Student(String类型的值, boolean类型的值)实例化了 name:" + name + " isSuccess:" + isSuccess);
showAllValue();
return; // 此方法默认就有这样一句return;隐式的,是可以让方法弹栈/结束;
} // 打印所有的成员变量值
private void showAllValue() {
System.out.println("id:" + id + "\nname:" + name + "\nage:" + age + "\nheight:" + height + "\n");
return; // 此方法默认就有这样一句return;隐式的,是可以让方法弹栈/结束;
}
}

main测试方法:

package android.java.oop06;

public class Demo01 {

    public static void main(String[] args) {

        // new Teacher();      --->        public Teacher(){}
Teacher teacher1 = new Teacher(); // new Student(9); ---> public Student(int value){}
Teacher teacher2 = new Teacher(9988); // new Student("刘俊", true); ---> public Student(String value1, boolean value2){}
Teacher teacher3 = new Teacher("毛对皮", true); } }

执行结果:

分析打印执行的结果中,每次调用构造方法,构造方法都会,先调用构造代码块,这是为什么呢,等结束完(构造方法隐式三行)就明白了;




构造方法隐式三行

  1.分析打印执行的结果中,每次调用构造方法,构造方法都会,先调用构造代码块,这是为什么呢?;

    解释:因为在所有构造方法中,【第三行】隐式的 会调用构造代码块;

  2.为什么构造代码块中打印的成员变量是有值得呢?

    解释:因为【第二行】给所有成员变量赋值了,所以构造代码块可以打印成员变量的值;

  3.为什么构造方法中打印的成员变量是有值得呢?

    解释:因为【第二行】给所有成员变量赋值了,所以构造方法可以打印成员变量的值;

package android.java.oop06.teacher;

public class Teacher {

    private int id = 007;
private String name = "零零发";
private int age = 98;
private float height = 1.78F; /**
* 构造代码块:每一个构造函数,的第三行执行者 就是构造代码块;
* 构造代码块可以给成员变量字段进行初始化工作等;
*/
{
System.out.println("构造代码块 被所有构造方法的第三行执行者 执行了...");
showAllValue();
} /**
* 每一个构造函数/所有构造函数都是这样的
* 就以此构造函数为例:来介绍隐式 第一行 第二行 第三行 执行操作
* 隐式的第一行、第二行、第三行、执行操作是默认执行的,是看不到的 隐式的
*/
public Teacher() {
// 【第一行】super(); 调用父类的 无参构造方法
/**
* 【第二行】
* 给所有成员属性赋值 例如:一开始这些成员变量的值是id=0 name=null age=0
* 就是执行了【第二行】才会去执行-->给id=赋值为007 name=赋值为="零零发" age=98)
*/
// 【第三行】调用-->(构造代码块) System.out.println("无参构造函数,我被new Teacher()实例化了");
showAllValue();
return; // 此方法默认就有这样一句return;隐式的,是可以让方法弹栈/结束;
} /**
* 每一个构造函数/所有构造函数都是这样的
* 就以此构造函数为例:来介绍隐式 第一行 第二行 第三行 执行操作
* 隐式的第一行、第二行、第三行、执行操作是默认执行的,是看不到的 隐式的
* @param value
*/
public Teacher(int value) {
// 【第一行】super(); 调用父类的 无参构造方法
/**
* 【第二行】
* 给所有成员属性赋值 例如:一开始这些成员变量的值是id=0 name=null age=0
* 就是执行了【第二行】才会去执行-->给id=赋值为007 name=赋值为="零零发" age=98)
*/
// 【第三行】调用-->(构造代码块) System.out.println("有参构造函数,我被new Teacher(int类型的值)实例化了 value:" + value);
showAllValue();
return; // 此方法默认就有这样一句return;隐式的,是可以让方法弹栈/结束;
} /**
* 每一个构造函数/所有构造函数都是这样的
* 就以此构造函数为例:来介绍隐式 第一行 第二行 第三行 执行操作
* 隐式的第一行、第二行、第三行、执行操作是默认执行的,是看不到的 隐式的
* @param name
* @param isSuccess
*/
public Teacher(String name, boolean isSuccess) {
// 【第一行】super(); 调用父类的 无参构造方法
/**
* 【第二行】
* 给所有成员属性赋值 例如:一开始这些成员变量的值是id=0 name=null age=0
* 就是执行了【第二行】才会去执行-->给id=赋值为007 name=赋值为="零零发" age=98)
*/
// 【第三行】调用-->(构造代码块) System.out.println("无参构造函数,我被new Student(String类型的值, boolean类型的值)实例化了 name:" + name + " isSuccess:" + isSuccess);
showAllValue();
return; // 此方法默认就有这样一句return;隐式的,是可以让方法弹栈/结束;
} // 打印所有的成员变量值
private void showAllValue() {
System.out.println("id:" + id + "\nname:" + name + "\nage:" + age + "\nheight:" + height + "\n");
return; // 此方法默认就有这样一句return;隐式的,是可以让方法弹栈/结束;
}
}

Android-Java构造代码块&构造方法隐式三行的更多相关文章

  1. java学习(一)静态代码块 构造代码块 构造方法的执行顺序及注意问题

    今天我总结了一下java中静态代码块 构造代码块 构造方法的执行顺序及其注意问题 首先要知道静态代码块是随着类的加载而加载,而构造代码块和构造方法都是随着对象的创建而加载 当时做了这么一个小案例(想必 ...

  2. Java面试题 静态代码块 构造代码块 构造方法 的执行顺序

    JAVA中的静态代码块 构造代码块 构造方法执行顺序: 静态代码块(类加载时执行)>>构造代码块>>构造方法 下面展示一个简单的例子,推荐大家动手运行一遍: public cl ...

  3. Java类中代码的执行顺序 静态代码块>构造代码块>构造方法

    一:静态代码块 注意是代码块,不是静态函数.函数要调用才执行,代码块加载就执行,一般是静态变量的声明与初始化.被static修饰的代码块(赋值.输出操作等).类中静态语句块仅在类加载时被执行一次 如 ...

  4. Java学习之代码块(静态,构造代码块,构造方法)执行顺序

    静态代码块   static{ 代码 } 随着类的加载而加载,随类的消失而消失,存在于类中,方法外,最先执行,且只加载1次,可用来加载驱动及初始化对象属性. 构造代码块   {   } 也存在于类中, ...

  5. JAVA 构造代码块

    class G{ G(){ System.out.println("我是无参构造方法"); } G(String name){ System.out.println("我 ...

  6. Java:构造代码块,静态代码块

    本文内容: 局部代码块 构造代码块 静态代码块 补充 首发日期:2018-03-28 局部代码块: 局部代码块用于限制变量的生命周期,如果希望某些变量在某一过程之后直接失效而不希望被后面继续操作时,可 ...

  7. java构造代码块详解

    一.简介 首先说一下,Java中有哪些代码块. 普通代码块 就是在方法后面使用"{}"括起来的代码片段,不能单独执行,必须调下其方法名才可以执行. 静态代码块 在类中使用stati ...

  8. java构造代码块,构造函数和普通函数的区别和调用时间

    在这里我们谈论一下构造代码块,构造函数和普通函数的区别和调用时间.构造代码块:最早运行,比构造函数运行的时间好要提前,和构造函数一样,只在对象初始化的时候运行.构造函数:运行时间比构造代码块时间晚,也 ...

  9. java构造代码块与静态代码块

    一:构造代码块 1.概述 作用:给对象初始化. 优先级:优先于对象的构造函数之前执行. { /*构造代码块的代码*/ } 给所有的对象统一的初始化,而构造函数只是给特定的对象初始化,因为构造函数可以重 ...

随机推荐

  1. VisualStudio使用技巧

    控制台工程去除黑框 刚学习OpenGL,绘制图形的时候,如果不进行设置,运行的时候会先出现黑窗口再出现Windows窗口.其实要去除控制台窗口非常简单,只需要修改工程设置,把子系统改成Windows, ...

  2. 一个漂亮的lazarus做的pagecontrol

    厌倦了屏幕上的默认灰色?让我们来欣赏一下商业配色. 这个组件实现了高光,点睛色,描边边等效果, 再配几组色彩,应该非常不错. 基于 lazarus 1.08 大家可以上 www.fpccn.com 看 ...

  3. virualbox问题

    出不来64位虚拟系统 bios设置虚拟化可用 2.创建虚拟机 启动不了 提示 不能打开一个... 安装exten 扩张包 3.设备 -- 安装增强功能... 分辨率  设置成功

  4. 事务 TRANSACTION

    事务是数据库中一个但单独的执行单元(Unit),他通常由高级数据库操作语言(如SQL)或编程语言(如C++.Java)编写的用户程序的执行所引起.当在数据库中更改数据成功时,在事务中更改的数据便会提交 ...

  5. c++11 多线程依次打印ABC

    并发 练习代码 #include <thread> #include <vector> #include <mutex> #include <iostream ...

  6. Mockito学习(zz)

    junitmaven软件测试框架项目管理  Mockito是一个流行的Mocking框架.它使用起来简单,学习成本很低,而且具有非常简洁的API,测试代码的可读性很高.因此它十分受欢迎,用 户群越来越 ...

  7. Linux学习笔记:Jenkins的使用

    在windows中使用Jenkins(Linux系统下类似),步骤是: 1 从官网下载jenkins项目的war包 2 将jenkins.war放到tomcat的webapps目录中,启动tomcat ...

  8. 利用HBuilder开发基于MUI的H5+ app中使用百度地图定位功能

    定位功能有两种方法: 首先要初始化内置地图: var map = new plus.maps.Map("map"); 这里黄色的map是html里面的id: <div id= ...

  9. 用EventLog Analyzer的预定义报表和告警来进行Syslog管理

    用EventLog Analyzer的预定义报表和告警来进行Syslog管理 系统日志(Syslog)管理是几乎所有企业的重要需求.系统管理员将syslog看作是解决网络上系统日志支持的系统和设备性能 ...

  10. Python中subprocess 模块 创建并运行一个进程

     python的subprocess模块,看到官方声明里说要尽力避免使用shell=True这个参数,于是测试了一下: from subprocess import call import shlex ...