为什么C++中的类不能定义自身类的对象?

  • Post author:
  • Post category:其他



最近在做C++套题时,遇到一个一个选择题,原题如下:


有如下类声明:

 class Te{
        public:
            Te();              //①
            Te te;             //②
            Te *pte;           //③
            void f(Te &rte);   //④
        };


看题后解析,解释的原因是“本题考查类的定义和对象的定义,题目中定义类Te中又定义了Te类型的对象te,这样陷入循环中,所以②是错误的,答案为B选项”,可是自己还是不怎么明白,“陷入循环,”,这是怎么回事啊?


处于好奇自己上网进行了相关的查询。


原因就是:在C++中,在定义对象的时候就创建了对象的实例,即分配了对象的内存空间。在java中,只有调用new的方法才能创建对象的实例,在内存中分配对象的空间。所以,如果在定义的时候就定义自身类的对象,就会导致递归创建对象的现象,创建了对象aa,因为aa是一个A类的实例,那么aa中还有一个aa对象,还要创建一个aa对象,为其分配内存…………,这样就会导致递归创建对象,结果就是内存被消耗殆尽。当然,这样的设计本身也不合理。


也就是说在C++的类定义中,是不能够在类中定义自身类的对象的,但是可以定义自身类的指针对象和引用。


比如:

class A
{
public:
 A ()
 {
  cout<<"Constructor method."<<endl;
 };
 A aa;
};
 
void main()
{
 A aaaaa;
}


上面程序出现的问题就是:以上代码编译提示错误,a’ : uses ‘A’, which is beingdefined。


如果把a换成*a就可以了


除此之外,自己也有意外的收获,那就是C++不可以,但是Java是可以的,而java就可以在类中定义自身类的对象。


例如:

class a{
  public a aa;
 }


这样的代码可以顺利编译,但是如果在定义的时候创建了对象实例,则也会编译失败的。在书上会经常看到这样的例子;

public class A()
{
    int yy=0;

    public static void main(String[] agrs)

    {
        A aa=new A();

    }
}


public static void main(String[] agrs)


这是一般应用程序的入口,可以直接运行的,与自身类没有太大的关系。你可以理解为在创建一个带有main方法的类,然后再调用A类。


aa.main(参数)这个可以这样使用,但不能是这样的形式,不然不就是无限递归了吗,最后会内存溢出.


在JAVA中,对象只有在new时才能创建对象实例,所以类中可以定义自身类的对象。如果把上例修改成令一个类的实例,则不会有任何问题。

class a{
  public e ee= new e();
 }


这样的话是可以正常编译运行的,这也是c++与Java的不同。









版权声明:本文为u010955843原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。