Poiché è un vettore di A
s e non A*
s, a
non può contenere sé stesso. Ma questo push_back
aggiungerà al vettore una copia di a
al momento della chiamata.
Esempio:
#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;
}
E l'output:
0xbff4fa20=[
0x9ec2008=[]
]
0xbff4fa20=[
0x9ec2018=[]
0x9ec2024=[
0x9ec2038=[]
]
]
0xbff4fa20=[
0x9ec2048=[]
0x9ec2054=[
0x9ec20a0=[]
]
0x9ec2060=[
0x9ec2080=[]
0x9ec208c=[
0x9ec2008=[]
]
]
]
Un default costruito 'std :: vector ' in realtà non contiene alcuna Un di, in modo che è cool. Hai provato un secondo push_back? –
http://stackoverflow.com/questions/4173254/what-is-the-curiously-recurring-template-pattern-crtp –
@BoPersson L'ho fatto ora e funziona. –