zoukankan      html  css  js  c++  java
  • 课件中动手动脑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进行调用时,就不会报错。

  • 相关阅读:
    sql语句中的通配符
    Q&A 20090922
    Web大文件上传
    作别2010, 迎来2011的第一个工作日
    .Net 中 获取当前应用程序启动目录的几个方法
    asp.net身份验证和使用Silverlight的问题
    常用正则表达式
    最完美的xslt数值函数与字符串函数
    SQL2005的分页存储过程,支持多表多关联,亲测高效绝对可用
    处理大并发下的dropdownlist数据关联
  • 原文地址:https://www.cnblogs.com/123456www/p/9824889.html
Copyright © 2011-2022 走看看