FrankyIsking
Arlen_hu
2017-11-03 09:09
采纳率: 50%
浏览 1.7k
已采纳

java程序语言设计进阶版习题答案

图片说明

这两个习题有啥错误呀

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

3条回答 默认 最新

  • a521314963
    a521314963 2017-11-03 09:19
    已采纳

    左边的怎么自己new自己啊,这样编译没问题运行起来不行吧
    先问下,问什么不能new自己。
    当然,假如按楼主的写法,当这个A第一次被调用的时候,就出抛异常,超出堆栈、内存溢出之类。
    楼主,你需要理解“声明”和“实例化”的概念。
    A a;
    即是声明,创建了一个A类型的变量a
    new A();
    即是实例化,实实在在地在内存里为A()划分了一块内存空间
    a=new A();即是使a指向new A()。以后只要你不更改a的引用,对a的任何操作都会影响到你分配出来的这块内存空间。
    理解了这个再回到问题
    public class A{}
    这个是对类的一个定义,此时,A只是一个“概念”,在电脑里并没有实体存在,但是java的虚拟机(jvm)已经得知了该类的所有定义,就是说,该类被加载进jvm的类加载器(class loader)了,其他的类有可能访问到该A类。
    此时A本身就是jvm中的一个类,它自己当然是和自己同包,对不对?
    所以A必然可以访问到A
    那么public class A{ A a=new A();}
    这句话,编译期是正确的,不存在错误,所以可以声明也(被jvm认为)可以实例化。
    但是到了运行期,真正的跑起来的时候,它是错误的
    因为这是个迭代的死循环。
    在new A()的时候,又会执行一遍A a= new A();
    然后该new A()又执行一遍A a= new A();
    如此往复,直到堆栈溢出。
    当然 以下写法是正确的
    public class A{
    A a=null;
    }

    点赞 评论
  • xinshuai_1
    编程一对一服务 2017-11-03 09:14

    左边的有错,但不知道错在哪里

    点赞 评论
  • jixinhuluwa
    Kind丶King 2017-11-03 09:23

    main()函数里面new Test(),会调用public Test()构造器,构造器里面又new Test,死循环了

    点赞 评论

相关推荐