信1403-2班20142897程怀远 ppt问题总结

本文探讨了Java中类成员初始化的顺序与规则,包括构造函数、初始化块等,并解析了如何正确地在静态方法中访问实例成员。

一、以下代码为何无法通过编译?哪儿出错了?

                       

答:Foo类中定义时引用了整型定义变量,上方new Foo()括号中应添加整型变量或数值。如果类提供了一个自定义的构造方法,将导致系统不再提供默认构造方法。

二、Java字段初始化的规律

源代码:

public class InitializeBlockClass {

  {

        field = 200;

  }

    public int field = 100;

    public InitializeBlockClass(int value){

      this.field = value;

  }

    public InitializeBlockClass()

    {

   

    }

    public static void main(String[] args)

    {

      InitializeBlockClass obj = new InitializeBlockClass();

      System.out.println(obj.field);

      obj = new InitializeBlockClass(300);

      System.out.println(obj.field);

    }

}

结果截图:

答:1、执行类成员定义时指定的默认值或类的初始化块,到底执行哪一个要看哪一个“排在前面”。

  2、执行类的构造函数类的初始化块不接收任何的参数,而且只要一创建类的对象,它们就会被执行。因此,适合于封装那些“对象创建时必须执行的代码”。

三、当多个类之间有继承关系时,创建子类对象会导致父类初始化块的执行,请自行编写示例代码验证以上结论。

答:程序代码:

class Root

{

  static{

     System.out.println("Root的静态初始化块");

  }

  {

     System.out.println("Root的普通初始化块");

  }

  public Root()

  {

     System.out.println("Root的无参数的构造器");

  }

}

  class Mid extends Root

  {

  static{

     System.out.println("Mid的静态初始块");

  }

  {

     System.out.println("Mid的普通初始化块");

  }

  public Mid()

  {

     System.out.println("Mid的无参数的构造器");

  }

  public Mid(String msg)

  {

     //通过this调用同一类中重载的构造器

     this();

     System.out.println("Mid的带参数构造器,其参数值:" + msg);

  }

}

class Leaf extends Mid

{

  static{

     System.out.println("Leaf的静态初始化块");

  }

  {

     System.out.println("Leaf的普通初始块");

  }

  public Leaf()

  {

     //通过super调用父类中有一个字符串参数的构造器

     super("Java初始化顺序演示");

     System.out.println("执行Leaf的构造");

  }

 

}

 

public class TestStaticInitializeBlock

{

  public static void main(String[] args)

  {

     new Leaf();

  }

}

 

四、静态初始化块的执行顺序

答:1、静态初始化块只执行一次。

  2、创建子类型的对象时,也会导致父类型的静态初始化块的执行。

五、静态方法中只允许访问静态数据,那么,如何在静态方法中访问类的实例成员(即没有附加static关键字的字段或方法)?

答:如下代码:

class StaticDemo {

 

      static int x; 

      int y;

      static public int getX() {

        return x;

 

     }

      static public void setX(int newX) {

 

        x = newX;

      }

 

      public int getY() {     return  y;

 

      }

      public void setY(int newY) {

 

        y = newY;

      }

 

  }

  public class ShowDemo {

 

      public static void main(String[] args) {

 

         System.out.println("静态变量x="+StaticDemo.getX());

 

        

        StaticDemo a= new StaticDemo();

        StaticDemo b= new StaticDemo();

 

        a.setX(1);

        a.setY(2);

 

        b.setX(3);

        b.setY(4);

 

        System.out.println("静态变量a.x="+a.getX());

        System.out.println("实例变量a.y="+a.getY());

 

        System.out.println("静态变量b.x="+b.getX());

        System.out.println("实例变量b.y="+b.getY());

    }

  }

包括访问实例变量。

 

转载于:https://www.cnblogs.com/chy-916/p/4887580.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值