为什么C++中的类不能定义自身类的对象,而java可以? 【转载】

在C++的类定义中,是不能够在类中定义自身类的对象的,但是可以定义自身类的指针对象和引用。
  1. class A
  2. {
  3.     public:()
  4.      {
  5.           cout<<"Constructor method."<<endl;
  6.      };
  7.      A aa;
  8. };
  9.  
  10. void main()
  11. {
  12.      A aaaaa;
  13. }

以上代码编译提示错误,a' : uses 'A', which is being defined。如果把a换成*a就可以了。
 
而java就可以在类中定义自身类的对象。
  1. class a{
  2.   public a aa;
  3.  }
这样的代码可以顺利编译,但是如果在定义的时候创建了对象实例,则也会编译失败的。
  1. class a{
  2.   public a aa = new a();
  3.  }

提示错误:
Exception in thread "main" java.lang.StackOverflowError at test1$abc.<init>(test1.java:4)
很明显,堆栈溢出了。为什么呢? 其实以上问题的本质是一致的,就是是创建对象实例的时机问题
 
在C++中,在定义对象的时候就创建了对象的实例,即分配了对象的内存空间。在java中,只有调用new的方法才能创建对象的实例,在内存中分配对象的空间。所以,如果在定义的时候就定义自身类的对象,就会导致递归创建对象的现象,创建了对象aa,因为aa是一个A类的实例,那么aa中还有一个aa对象,还要创建一个aa对象,为其分配内存…………,这样就会导致递归创建对象,结果就是内存被消耗殆尽。当然,这样的设计本身也不合理。
在JAVA中,对象只有在new时才能创建对象实例,所以类中可以定义自身类的对象。如果把上例修改成令一个类的实例,则不会有任何问题。
class a{
  public b bb = new b();
 }
这样的代码是可以编译并运行的。
但如果在java的类中用new创建自身的对象时,将其声明为static则是可以的。这是因为static成员只在类的对象被创建或类的静态成员(方法)被调用时进行一次初始化,其后即再不创建和初始化。
 
想想这个方法在单例模式里面不是经常使用到吗?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值