zoukankan      html  css  js  c++  java
  • 程序设计及总结

    请输入并运行以下代码,得到什么结果?

    package com;

    public class Test {

       //  public static int value=1;//类变量,跟main是同级关系

    public static void main(String[] args) {

               Foo obj1=new Foo();

               Foo obj2=new Foo();

               System.out.println(obj1==obj2);

    }

    }

    class Foo

    {

    int value=100;

    }

     

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

     

    上面Foo obj1=new Foo();的括号中少了下面定义的类中的参数initValue,在加 int initValue = 0

    package com;

    public class Test {

       //  public static int value=1;//类变量,跟main是同级关系

    public static void main(String[] args) {

              int initValue = 0;

    Foo obj1=new Foo(initValue);

    }

    }

    class Foo

    {

    int value;

    public Foo(int initValue){

    value=initValue;

    }

    }

    使用上页幻灯片中定义的类,以下代码输出结果是什么?

    package com;

    public class Test {

       //  public static int value=1;//类变量,跟main是同级关系

    public static void main(String[] args) {

    InitializeBlockClass obj=new InitializeBlockClass();

    System.out.println(obj.field);

    obj=new InitializeBlockClass(300);

    System.out.println(obj.field);

    }

    }

    class InitializeBlockClass {

    {

       field=200;

    }

    public int field=100;

    public InitializeBlockClass (int value){

    this.field=value;

    }

    public InitializeBlockClass (){

    }

    }

     

    输出的结果是100300,初始化以定义式的结果为准,在花括号中的结构为辅,在实际开发中不要这样写代码,应该尽量保证一个字段只初始化一次!

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

    package com;

    public class Test {

       //  public static int value=1;//类变量,跟main是同级关系

    public static void main(String[] args) {

    InitializeBlockClass obj=new InitializeBlockClass();

    {

    obj.field=200;

    }

    System.out.println(obj.field);

    obj=new InitializeBlockClass(300);

    System.out.println(obj.field);

    InitializeBlockNext obj1=new InitializeBlockNext();

    System.out.println(obj1.field1);

    obj1=new InitializeBlockNext(500);

    System.out.println(obj1.field1);

    InitializeBlockBack obj2=new InitializeBlockBack();

    System.out.println(obj2.field2);

    obj2=new InitializeBlockBack(600);

    System.out.println(obj2.field2);

    }

    }

    class InitializeBlockClass {

    public int field=100;

    public InitializeBlockClass (int value){

    this.field=value;

    }

    public InitializeBlockClass (){

    }

    }

    class InitializeBlockNext{

    public int field1=100;

    public InitializeBlockNext (int value){

    this.field1=value;

    }

    public InitializeBlockNext (){

    }

    }

    class InitializeBlockBack{

    {

       field2=200;

    }

    public int field2=100;

    public InitializeBlockBack (int value){

    this.field2=value;

    }

    public InitializeBlockBack (){

    }

    }

     

    请运行TestStaticInitializeBlock.java示例,观察输出结果,总结出“静态初始化块的执行顺序”。

    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();

    }

    }

    首先执行父类静态的内容,父类静态的内容执行完毕后,接着去执行子类的静态的内容,当子类的静态内容执行完毕后再去看父类有没有非静态代码块。如果有就执行父类的非静态代码块,父类的非静态代码块执行完毕,接着执行父类的构造方法;父类的构造方法执行完毕后接着看子类有没有非静态代码块,如果有就执行子类的非静态代码块。子类的非静态代码块执行完毕执行构造方法。总之静态代码块内容优先,然后是父类的非静态代码块和构造方法,做后是子类的非静态代码块和构造方法。

     

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

    请编写代码验证你的想法。

    package demo;

    class StaticDemo{

    static int x;//静态 变量 x

    int y;//实例 变量 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) {

    // TODO 自动生成的方法存根

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

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

             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.x="+a.getY());

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

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

    }

    }

     

    静态方法只能访问静态成员,实例方法可以访问静态和实例成员。之所以不允许静态方法访问实例成员变量,是因为实例成员变量是属于某个对象的,而静态方法在执行时,并不一定存在对象。同样,因为实例方法可以访问实例成员变量,如果允许静态方法调用实例方法,将间接使用实例成员变量,所以他不能调用实例方法。

    动手练习

    不使用Eclipse,直接使用命令行运行Test1.javaTest2.JavaTest3.Java

     

    跟踪对象

    分析:定义一个函数getNumber();用来计算创建对象的个数。定义一个整数型i.用来数对象个数。

    package dome;

      

    public class Num {

        private static double i;

          public Num(){

           i++;

          }

          public static double getNumber(){

           return i;

          }

    public static void main(String[] args) {

    // TODO 自动生成的方法存根

            Num d1=new Num();

            Num d2=new Num();

            Num d3=new Num();

            Num d4=new Num();

           

            System.out.println("一共创建了"+Num.getNumber()+"个对象");

    }

    }

  • 相关阅读:
    sql当前行数据和之前行数据相加减循环处理
    Sql 查询库、表、列名的语句
    sql 特殊字符替换
    pandas 篇
    JAVA学习--面向对象的特征二:继承性
    JAVA学习--super使用
    JAVA学习--方法的参数传递
    JAVA学习--可变个数的形参的方法
    JAVA学习--面向对象思想的落地法则
    JAVA学习--方法的重载
  • 原文地址:https://www.cnblogs.com/wanggong2014/p/4887931.html
Copyright © 2011-2022 走看看