1. Java 的构造函数 与初始化块:

a. 抽象类的构造函数

若果在父类中(也就是抽象类)中显示的写了有参数的构造函数,在子类是就必须写一个构造函数来调用父类的构造函数

abstract class Person {   //定义一个抽象类,必须被继承

Person(int i) {

}

}

public class Student extends Person {

Student() {

super(int i)://必须显示的调用父类构造方法//super代表父类对象

}

}

b. 构造函数

public class Sample{

// 第一:在这a=1

static int a

// 第二:a=2

static{ a=2;}

// 第三:a=4

static{  a=4;}

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

// 第四:a=4,执行之后a=5

a++;

// 第五:a=5

System.out.println("a="+a);

}

}

引段网友对类的加载及生命周期的说明:

当类不被用到的时候,什么都不提前加载,

(1)一旦类被使用到(import时),首先加载的是它的静态变量,然后是静态初始化块,静态方法(不调用时不执行)。

(2)当此类要被构造一个对象(new 时)的时候,即被new,或者用反射生成其对象的时候,加载其成员部分。依次为成员变量(即非静态变量)、非静态初始化块、非静态方法、最后才是构造器(不创建实例时不执行)。

成员部分除方法外,每个对象都有其一份副本,其中,非静态方法并不是每个对象都有一个,而是所有对象共享一个副本,这点要注意。

静态部分一旦被加载,就不会被销毁,直到程序结束,关闭虚拟机。

非静态的,即,被各个对象所拥有的东西,当对象不被引用时,这个类就结束了他的生命周期。

但是,它还要在内存中驻留一段时间,等垃圾处理器来将它清除。

在失去引用后,被垃圾处理前的这段时间,虽然它驻留在内存中,但是没法被再次引用。

请注意上面说明的加载顺序:

首先加载 静态变量 然后是静态初始化块,最后是静态方法。

为了验证这个顺序,将上面的代码稍微改了下,添加了个静态方法。

如下

package test1;

public class ClassLoadTest

{

static  int a=2;

static{ a=3;}

static{a=4;}

static void init() {a=10;}

/** * @param args

*/

public static void main(String[] args)

{

System.out.println("a="+a);//+为连字符

}

}

结果输出为:a=4

1.构造函数

(1)任何一个类不管它是抽象的还是具体的,都拥有一个构造函数,即使程序员不键入它,Java也会提供一个默认的无参的构造函数。构造函数必须要与类同名,构造函数一定不能够有返回类型,切记void也是一种返回类型!

如果在类中没有创建任何构造函数,那么系统将使用默认的构造函数,如果程序员定义了一个构造函数,那么默认的构造函数将不存在!

public class Book {

private String id;

private String title;

private String author;

//我们自己定义一个构造函数

public Book(String idIn,String titleIn,String authorIn){

id=idIn;

title=titleIn;

author=authorIn;

}

public String toString(){

return "The info of the book:\n"+

"Title:"+title+"\n"+

"Author:"+author+"\n";

}

}

public class Test {

public static void main(String[]args){

//Book book=new Book();    使用默认的构造函数将出现编译错误

Book book=new Book("0101001","Thinking in Java","Bruce Eckel");

System.out.println(book);

}

}

(2)构造函数的执行方式:

首先调用其超类的构造函数,超类构造函数又调用其超类构造函数,直至到达Object构造函数为止,然后Object()构造函数执行,直到所有的构造函数完成

public class Animal {

public Animal(){

System.out.println("This is the animal constructor");

}

}

public class Snake extends Animal{

public Snake(){

System.out.println("This is snake constructor");

}

}

public class Cobra extends Snake{

public Cobra(){

System.out.println("This is the cobra constructor");

}

}

public class Test {

public static void main(String[]args){

new Cobra();

}

}

执行结果:

This is the animal constructor

This is snake constructor

This is the cobra constructor

(3)默认构造函数是一个无变元的构造函数,隐式的包含了一个对super()的调用

如果一个子类的超类没有无参的构造函数,那么其子类必须程序员实现构造函数,而无法调用默认的构造函数

public class Rpg {

private int hp;

private int mp;

private int grade;

private int exp;

public Rpg(int hpIn,int mpIn,int gradeIn,int expIn){

hp=hpIn;

mp=mpIn;

grade=gradeIn;

exp=expIn;

}

}

public class Magician extends Rpg{

//public Magician(){   不可以使用默认的构造函数!

//}

public Magician(int hpIn,int mpIn,int gradeIn,int expIn){

super(hpIn,mpIn,gradeIn,expIn);

}

}

(4)构造函数可以重载,如果在同一个类中一个构造函数需要调用另一个重载的构造函数,可以使用this(),this()的变元列表决定了调用哪个具体的构造函数

注意:this()和super()必须出现在构造函数的第一行!!!而且this()和super()函数不能位于同一个构造函数中!!!

抽象类的构造函数在实例化具体子类时被调用

接口是没有构造函数的!

2.初始化块:

Java类中执行操作的地方有三个:

构造函数、方法和初始化块

Java初始化块分为静态初始化块和实例初始化块:

首次加载类时,会运行一次静态初始化块,每次创建一个新实例时,都会运行一次实例初始化块,类中允许出现多个初始化块,它们所执行的顺序与它们在代码中所出现的顺序相同(程序执行时默认是从上到下的)

总体的执行顺序:静态初始化块->super()->实例初始化块->构造函数的其它部分,通过一个例子来说明:

public class Father {

public Father(){

System.out.println("This is super class!");

}

}

public class Test extends Father{

static{

System.out.println("This is static block!");//静态块

}

public Test(){

System.out.println("This is test constructor");//构造函数

}

public static void main(String[]args){

System.out.println("Hello,Java!");

Test test=new Test();

}

{

System.out.println("Common init block!");

}

}

上面的例子的输出结果是:

This is static block!

Hello,Java!

This is super class!

Common init block!

This is test constructor

Java 构造函数(抽象类中的构造函数) 和 加载的更多相关文章

  1. 记一次解决cmd中执行java提示"找不到或无法加载主类"的问题

    今天遇到一个问题:在cmd命令行中,用javac编译java文件可以成功,但是用java执行却提示“找不到或无法加载主类”.现将该问题的原因以及解决办法记录一下. 先理解一下系统变量path和clas ...

  2. Java虚拟机JVM学习02 类的加载概述

    Java虚拟机JVM学习02 类的加载概述 类的加载 类的加载指的是将类的.class文件中的二进制数据读入到内存中,将其放在运行时数据区的方法区内,然后在堆区创建一个java.lang.Class对 ...

  3. java 27 - 1 反射之 类的加载器

    说到反射,首先说类的加载器. 类的加载: 当程序要使用某个类时,如果该类还未被加载到内存中,则系统会通过加载,连接,初始化三步来实现对这个类进行初始化. 加载: 就是指将class文件读入内存,并为之 ...

  4. Qt中如何 编写插件 加载插件 卸载插件

    Qt中如何 编写插件 加载插件 卸载插件是本文要介绍的内容.Qt提供了一个类QPluginLoader来加载静态库和动态库,在Qt中,Qt把动态库和静态库都看成是一个插件,使用QPluginLoade ...

  5. 编译和运行java文件 找不到或无法加载主类

    这边提供一个关于程序中含有package关键字,使用“终端”运行程序时出现“找不到或无法加载主类”,而使用Eclipse软件可以正常运行程序的可能解决办法. 例如程序名为HelloWorldTest. ...

  6. 移动设备的HTML页面中图片实现滚动加载

    如今移动互联网风靡全球,移动页面的元素也是丰富多彩,一个移动页面的图片超过10张已经是再正常不过的事情了.但是相对,很多移动用户还停留在2G,3G这样的网络中.那么这样带宽的用户,在浏览这样的页面时, ...

  7. Java 反射理解(二)-- 动态加载类

    Java 反射理解(二)-- 动态加载类 概念 在获得类类型中,有一种方法是 Class.forName("类的全称"),有以下要点: 不仅表示了类的类类型,还代表了动态加载类 编 ...

  8. EF如何操作内存中的数据以及加载相关联表的数据:延迟加载、贪婪加载、显示加载

    之前的EF Code First系列讲了那么多如何配置实体和数据库表的关系,显然配置只是辅助,使用EF操作数据库才是每天开发中都需要用的,这个系列讲讲如何使用EF操作数据库.老版本的EF主要是通过Ob ...

  9. imagesLoaded – 检测网页中的图片是否加载

    imagesLoaded 是一个用于来检测网页中的图片是否载入完成的 JavaScript 工具库.支持回调的获取图片加载的进度,还可以绑定自定义事件.可以结合 jQuery.RequireJS 使用 ...

  10. 在Unity3D的网络游戏中实现资源动态加载

    用Unity3D制作基于web的网络游戏,不可避免的会用到一个技术-资源动态加载.比如想加载一个大场景的资源,不应该在游戏的开始让用户长时间等待全部资源的加载完毕.应该优先加载用户附近的场景资源,在游 ...

随机推荐

  1. Java多线程-两种常用的线程计数器CountDownLatch和循环屏障CyclicBarrier

    Java多线程编程-(1)-线程安全和锁Synchronized概念 Java多线程编程-(2)-可重入锁以及Synchronized的其他基本特性 Java多线程编程-(3)-从一个错误的双重校验锁 ...

  2. C# AES要解密的数据的长度无效

    加密方式  AES-CBC-128 将解密方法改成如下 public string Decrypt(string toDecrypt, string key) { if (string.IsNullO ...

  3. Android和IOS开发学习路线

    图片看上去太小,直接另存为吧 图片来自:http://www.finalshares.com/

  4. SpringMVC由浅入深day01_13springmvc和struts2的区别_14问题

    13 springmvc和struts2的区别 1.springmvc是基于方法开发(一个url对应一个方法),请求参数传递到方法的形参,可以设计为单例或多例(建议单例),struts2是基于类开发, ...

  5. 判断资源贴图是否有alpha

    /* modfly selected textures`s maxSize and ImportFormat bool hasAlpha = true; if(hasAlpha)then(textur ...

  6. Python标准异常和异常处理详解

    python提供了两个非常重要的功能来处理python程序在运行中出现的异常和错误.你可以使用该功能来调试python程序. 1.异常处理: 本站Python教程会具体介绍. 2.断言(Asserti ...

  7. MQTT-C-UDP_PUB

    /** ****************************************************************************** * @file    apdu.c ...

  8. JSPatch 部署安全策略

    本文转载至 http://blog.cnbang.net/tech/2879/ 使用 JSPatch 有两个安全问题: 传输安全:JS 脚本可以调用任意 OC 方法,权限非常大,若被中间人攻击替换代码 ...

  9. Spring系列之访问数据库

    一.概述 Spring的数据访问层是以统一的数据访问异常层体系为核心,结合JDBC API的最佳实践和统一集成各种ORM方案,完成Java平台的数据访问. 二.JDBC API的最佳实践 Spring ...

  10. PowerDesigner快捷键【转】

    一般快捷键 快捷键 说明 F4 打开检查模型窗口,检查模型 F5 如果图窗口内的图改变过大小,恢复为原有大小即正常大小 F6 放大图窗口内的图 F7 缩小图窗口内的图 F8 在图窗口内中查看全部图内容 ...