Dado que es un vector de A
sy no de A*
s, a
no puede contenerse per se. Pero ese push_back
agregará al vector una copia de a
en el momento de la llamada.
Ejemplo:
#include <vector>
#include <iostream>
using namespace std;
class A : public std::vector<A>
{
public:
void print(int level=0){
for (int i=0;i<level;i++) cout<<" ";
cout << "0x" << hex << (unsigned int)this << "=[";
if (size()){
cout << endl;
for (int i=0; i<size(); i++)
(*this)[i].print(level+1);
for (int i=0;i<level;i++) cout<<" ";
}
cout <<"]"<<endl;
if(!level) cout << endl;
}
};
int main(){
A a;
for (int i=1;i<=3;i++){
a.push_back(a);
a.print();
}
return 0;
}
Y la salida:
0xbff4fa20=[
0x9ec2008=[]
]
0xbff4fa20=[
0x9ec2018=[]
0x9ec2024=[
0x9ec2038=[]
]
]
0xbff4fa20=[
0x9ec2048=[]
0x9ec2054=[
0x9ec20a0=[]
]
0x9ec2060=[
0x9ec2080=[]
0x9ec208c=[
0x9ec2008=[]
]
]
]
Un defecto construidos 'std :: vector ' realidad no contienen ninguna de A, por lo que está bien. ¿Has probado un segundo push_back? –
http://stackoverflow.com/questions/4173254/what-is-the-curiously-recurring-template-pattern-crtp –
@BoPersson Lo hice ahora, y funciona. –