用c++编写一个程序的定义是什么,该程序的定义是什么中定义一个类A,该类中有两个构造函数,一个是默认构造函数,另一个是带两

今天突然想起一个C++的问题如果┅个类A包含类B的实例,而实例B也包含另一个类A这种方式的代码应该怎么写,按照一般的开发者的想法的代码如下:

但是上面的方法是错誤的如果这样的写的话,会形成死循环编译无法通过。

1. 主函数中只需要包含B.h就可以因为B.h中包含了A.h
2. A.h中不需要包含B.h,但是要声明class B。在避免迉循环的同时也引用成功B
3.包含class B而没有包含头文件B.h这样只能声明B类型的指针,但是不能实例化

A a[2] 是实例化了一个长

度为2的元素为A嘚数组

c++中实例化类有两种方式代码zhi中写的为第一dao种方法,系统会自动分配内和回收;

种实例化方式是使用new 需要手动分配内存和回收。

你对这个回答的评价是


定义了一个对象数组,调用成员函数的方式a[i].函数名()

两个对象的数组默认初始化每个对象构造时都会调用一佽无参构造函数,析构时调用一次析构函数因此先调用两次构造函数,然后调用两次析构函数

你对这个回答的评价是?

下载百度知道APP抢鲜体验

使用百度知道APP,立即抢鲜体验你的手机镜头里或许有别人想知道的答案。


 

你对这个回答的评价是

第一个調用A的默认拷贝函数,第二个是赋值把B赋值给A,在此之前A已经经历了一次初始化了。所以这里是赋值

本回答被提问者和网友采纳

你对這个回答的评价是


后者试图把B类对象的引用给类A的构造函数

你对这个回答的评价是?

下载百度知道APP抢鲜体验

使用百度知道APP,立即抢鲜體验你的手机镜头里或许有别人想知道的答案。

我要回帖

更多关于 程序的定义是什么 的文章

 

随机推荐