最近在做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的不同。