zoukankan      html  css  js  c++  java
  • 课后作业 2

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

    ==”施加于原始数据类型变量时,是比较变量所保存的数据是否相等==”施加于引用类型变量时,是比较这两个变量是否引用同一对象。因为obj1 obj2是类Foo的两个对象,所以此时比较的是两个对象的地址,所以输出false

    2.

     

    一是执行类成员定义时指定的默认值或类的初始化块,到底执行哪一个要看哪一个“排在前面”,二是执行类的构造函数。

    3.

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

    }

    }

    静态初始化块只执行一次。创建子类型的对象时,也会导致父类型的静态初始化块的执行。先执行父类静态初始化块然后再执行自己这个类的静态初始化块。

    4.

     

    类提供了一个自定义的构造方法,将导致系统不再提供默认构造方法。因为下面的Foo类中提供出了自己的构造方法,所以用new默认构造方法不再提供使用。

    5.


    public class Example
    {
    int x = 3;//类的实例变量,初始化值为3
    static int y = 4;//类的静态变量,初始化值为4
    public static void method()//静态方法
    {
    System.out.println("实例变量x = " + new Example().x);//在静态方法中访问类的实例变量需首先进行类的实例化
    System.out.println("静态变量y = " + y);//在静态方法中可直接访问类的静态变量
    }

    public static void main(String[] args)
    {
    Example.method();
    Example ex = new Example();
    System.out.println("x = " + ex.x);
    }
    }

    运行结果:

    类中静态的方法或者属性,本质上来讲并不是该类的成员,在java虚拟机装在类的时候,这些静态的东西已经有了对象,它只是在这个类中"寄居",不需要通过类的构造器(构造函数)类实现实例化;而非静态的属性或者方法,在类的装载是并没有存在,需在执行了该类的构造函数后才可依赖该类的实例对象存在。

    在外部调用静态方法时,可以使用"类名.方法名"的方式,也可以使用"对象名.方法名"的方式。而实例方法只有后面这种方式。也就是说,调用静态方法可以无需创建对象。

    静态方法在访问本类的成员时,只允许访问静态成员(即静态成员变量和静态方法),而不允许访问实例成员变量和实例方法;实例方法则无此限制。

      public static void main(String[] args) 

    {

      Example.method();

      Example ex = new Example();

    System.out.println("x = " + ex.x);

    }

    }

    6.

    public class ceshi {
    private int id;
    private String name;
    private static long count;
    private final static ThreadLocal tl=new ThreadLocal();

    public ceshi() {
    super();
    count++;
    tl.set(count);
    }
    public long getCount(){
    return (Long)tl.get();
    }
    public static void main(String[] args) {
    for (int i = 0; i < 5; i++) {
    ceshi t=new ceshi();
    System.out.println(t.getCount());
    }
    }

    }

  • 相关阅读:
    【转】随机函数的rand、srand用法
    realloc,malloc,calloc函数的区别
    c语言中time相关函数
    C语言strdup函数
    c语言strtod()函数的用法
    (转)从拜占庭将军问题谈谈为什么pow是目前最好的共识机制
    Linux命令行编辑快捷键
    少走弯路的10条忠告
    centos6下升级git版本的操作记录
    (转)Ctrl+H 浪潮Raid配置文档
  • 原文地址:https://www.cnblogs.com/muxiaozhou/p/5984294.html
Copyright © 2011-2022 走看看