• 课件中动手动脑3


    (1)以下代码为何无法通过编译?哪儿出错了?

    由于在Foo类中定义了有以int类型为参数的构造函数,所以在对对象进行初始化时,在系统自动调用构造函数时,需要有一个int型变量作为实参,但是在该主函数中,在调用时没有赋予构造函数以实参,所以会出错。

    2Java字段初始化的规律

    测试代码:

    package 包;
    public class main {
        /**
         * @param args
         */
        public static void main(String[] args) {
            // TODO 自动生成的方法存根
            int x=50;
            t d=new t(x);
            System.out.println(d.n);
        }
    }
    package 包;
    
    public class t {
        {
            n=100;
        }
        public int n=200;
        public t(int x)
        {
            this.n=x;
        }
    }

    在测试代码中,既有初始化块,又重写了构造函数,又设定了字段的初始值,最后输出结果为50,所以当三者都存在时,构造函数为主,而初始化块与对字段初始值的设定,它们优先性相等,所以谁在后面谁起作用。

    3)静态初始化块的执行顺序

    测试代码:

    public class f {
        {
            System.out.println("执行f的非静态初始化块");
        }
        static
        {
            System.out.println("执行f的静态初始化块");
        }
        public f()
        {
            System.out.println("f的无参数构造器");
        }
    }
    public class s extends f{
        {
            System.out.println("执行s的非静态初始化块");
        }
        static
        {
            System.out.println("执行s的静态初始化块");
        }
        public s()
        {
            System.out.println("s的无参数的构造器");
        }
        public s(String a)
        {
            this();//调用该类中重载的构造器
            System.out.println("s的带参数的构造器"+a);
        }
    }
    public class t extends s{
        {
            System.out.println("执行t的非静态初始化块");
        }
        static
        {
            System.out.println("执行t的静态初始化块");
        }
        public t()
        {
            super("haha");
            System.out.println("t的构造器");
        }
    }
    public class main {
        /**
         * @param args
         */
        public static void main(String[] args) {
            // TODO 自动生成的方法存根
            t g=new t();
        }
    }

    在继承与派生时,当对新的子类进行初始化时,父类的静态初始化块,非静态初始化块,构造器都会被调用,在被调用时,会首先调用静态初初始化块,如当有父类以及父类的父类时,先调用三者的静态初始化块,而且所有的静态初始化块执行且执行一次。

    (4)如何在静态方法中访问类的实例成员:

    测试代码:

    package 包;
    public class text {
        static String a="静态成员";
        String b="非静态成员";
        static void ttt()
        {
            System.out.println("调用"+a);
            System.out.println("调用"+new text().b);//进行对象实例化
        }
    }
    public class main {
        /**
         * @param args
         */
        public static void main(String[] args) {
            // TODO 自动生成的方法存根
            text.ttt();
        }
    }

    静态的方法通过一般形式只能调用静态的成员,在对非静态成员即实例成员进行调用时,必须通过对实例化的对象的实例成员的调用,在测试代码中,如果直接用方法ttt()对非静态成员b进行调用时,系统会报错,而在对实例化过后的对象的成员b进行调用时,就不会报错。

  • 相关阅读:
    深入浅出JSONP--解决ajax跨域问题
    Apache与Tomcat的区别
    项目终于接近尾声了
    交互设计[小插曲]--网站UI配色
    使用 Jasmine 进行测试驱动的 JavaScript 开发
    javascript单元测试
    MySQL查询当前数据库中所有记录不为空的表
    cannot be resolved to a type的错误
    oracle 表空数据导出dmp ,空表导出失败
    Iterable<E> Iterator<E>
  • 原文地址:https://www.cnblogs.com/123456www/p/9824889.html
Copyright © 2020-2023  润新知