Недавно у меня возникла очень странная проблема с кодом на C++. Я воспроизвел случай в минималистском примере. У нас есть класс Яйцо:C++ ostringstream странное поведение
class Egg
{
private:
const char* name;
public:
Egg() {};
Egg(const char* name) {
this->name=name;
}
const char* getName() {
return name;
}
};
Мы также имеем класс корзины для хранения яиц
const int size = 15;
class Basket
{
private:
int currentSize=0;
Egg* eggs;
public:
Basket(){
eggs=new Egg[size];
}
void addEgg(Egg e){
eggs[currentSize]=e;
currentSize++;
}
void printEggs(){
for(int i=0; i<currentSize; i++)
{
cout<<eggs[i].getName()<<endl;
}
}
~Basket(){
delete[] eggs;
}
};
Так вот пример, который работает, как ожидалось.
Basket basket;
Egg egg1("Egg1");
Egg egg2("Egg2");
basket.addEgg(egg1);
basket.addEgg(egg2);
basket.printEggs();
//Output: Egg1 Egg2
Это ожидаемый результат, но если я хочу добавить N яйцо с сгенерированными именами в зависимости от некоторых переменного цикла, У меня есть следующие проблемы.
Basket basket;
for(int i = 0; i<2; i++) {
ostringstream os;
os<<"Egg"<<i;
Egg egg(os.str().c_str());
basket.addEgg(egg);
}
basket.printEggs();
//Output: Egg1 Egg1
Если изменить условие цикла, чтобы я < 5, я получаю "Egg4 Egg4 Egg4 Egg4 Egg4". Он сохраняет последнее добавленное яйцо во всех индексах динамического массива Egg.
После некоторого поиска в google я обнаружил, что задание переменной char * name в Egg фиксированного размера и использование strcpy
в конструкторе устраняет проблему.
Вот «фиксированный» класс яйца.
class Egg
{
private:
char name[50];
public:
Egg(){};
Egg(const char* name)
{
strcpy(this->name, name);
}
const char* getName()
{
return name;
}
};
Теперь вопрос в том, почему? : D
Заранее спасибо.
Here является ссылкой на весь код.
Поскольку вы используете C++, гораздо лучше использовать 'std :: string', чем старые функции строки C. – tadman
Да, я не так хорош с C++. Просто хотел создать пример для случая –
Согласен, используйте 'std :: string' и' std :: vector' + напишите свой собственный конструктор копий, так как я предполагаю, что вы испытываете неопределенное поведение. – JVApen