Я создаю бинарное представление дерева математического выражения для выполнения различных и интеграции. Это отлично работает для: < /p>
Symbol("x") + Symbol(2.3);
< /code>
Проблема возникает, когда я хочу поддерживать такие выражения, как: < /p>
Symbol("x") + 2.3;
< /code>
Где объект символа добавляется в двойную (плавающую запятую). < /p>
Я реализовал два подхода:
подход 1 (работает, но имеет дублирование кода) < /strong> < /p>
Symbol operator+(double other){
Symbol *temp = new Symbol(other);
if (this->is_constant) {
double value = this->value + temp->value;
Symbol temp2(value);
return temp2;
}
Symbol temp2;
temp2.op = '+';
temp2.left = this;
temp2.right = temp;
return temp2;
}
< /code>
Это работает, но логика для добавления двух объектов символа практически идентична этой функции, что приводит к избыточному коду. < /p>
подход 2 (вызывает ошибку сегментации) < /strong>
, чтобы уменьшить избыточность, я пытался: < /p>
< /strong>
, я пытался: < /p>
< /rong>
, я пытался: < /p>
< /strong>
.Symbol operator+(double other){
Symbol *temp = new Symbol(other);
return *this + *temp; // Causes segmentation fault when try to access other later
}
< /code>
Symbol("x") + 2.3
Тем не менее, это приводит к ошибке сегментации, когда пытайтесь получить доступ к этому *Temp (2.3) объект в основном фекенции, потому что температура распределяется динамически, но Temp Pass копия этого объекта и его объем, потерянный после того, как эта функция заканчивается.
. /> Здесь является полным кодом для справки: < /p>
#include
#include
class Symbol{
public:
std::string name = "";
bool is_constant = false;
bool is_expression = false;
char op;
double value = 0.0;
Symbol* left = nullptr;
Symbol* right = nullptr;
Symbol() {is_expression = true;}
Symbol(std::string name) {this->name = name;}
Symbol(double value) {this->value = value; this->is_constant = true;}
~Symbol() {};
Symbol operator+(Symbol other){
if(this->is_constant & other.is_constant){
double value = this->value + other.value;
Symbol temp(value);
return temp;
}
Symbol temp;
temp.op = '+';
temp.left = this;
temp.right = &other;
return temp;
}
Symbol operator+(double other){
Symbol *temp = new Symbol(other);
if(this->is_constant){
double value = this->value + temp->value;
Symbol temp2(value);
return temp2;
}
Symbol temp2;
temp2.op = '+';
temp2.left = this;
temp2.right = temp;
return temp2;
// // uncomment below line and comment above function code and this will give segmentation fault
// return *this + *(new Symbol(other));
}
void print(){
if(this->is_expression){
std::cout left->print();
std::cout op right->print();
std::cout is_constant){
std::cout value
Подробнее здесь: https://stackoverflow.com/questions/794 ... uplication
Перегрузка+ оператор в C ++ для класса символов и избегание дублирования кода ⇐ C++
Программы на C++. Форум разработчиков
1756796762
Anonymous
Я создаю бинарное представление дерева математического выражения для выполнения различных и интеграции. Это отлично работает для: < /p>
Symbol("x") + Symbol(2.3);
< /code>
Проблема возникает, когда я хочу поддерживать такие выражения, как: < /p>
Symbol("x") + 2.3;
< /code>
Где объект символа добавляется в двойную (плавающую запятую). < /p>
Я реализовал два подхода:
подход 1 (работает, но имеет дублирование кода) < /strong> < /p>
Symbol operator+(double other){
Symbol *temp = new Symbol(other);
if (this->is_constant) {
double value = this->value + temp->value;
Symbol temp2(value);
return temp2;
}
Symbol temp2;
temp2.op = '+';
temp2.left = this;
temp2.right = temp;
return temp2;
}
< /code>
Это работает, но логика для добавления двух объектов символа практически идентична этой функции, что приводит к избыточному коду. < /p>
подход 2 (вызывает ошибку сегментации) < /strong>
, чтобы уменьшить избыточность, я пытался: < /p>
< /strong>
, я пытался: < /p>
< /rong>
, я пытался: < /p>
< /strong>
.Symbol operator+(double other){
Symbol *temp = new Symbol(other);
return *this + *temp; // Causes segmentation fault when try to access other later
}
< /code>
Symbol("x") + 2.3
Тем не менее, это приводит к ошибке сегментации, когда пытайтесь получить доступ к этому *Temp (2.3) объект в основном фекенции, потому что температура распределяется динамически, но Temp Pass копия этого объекта и его объем, потерянный после того, как эта функция заканчивается.
. /> Здесь является полным кодом для справки: < /p>
#include
#include
class Symbol{
public:
std::string name = "";
bool is_constant = false;
bool is_expression = false;
char op;
double value = 0.0;
Symbol* left = nullptr;
Symbol* right = nullptr;
Symbol() {is_expression = true;}
Symbol(std::string name) {this->name = name;}
Symbol(double value) {this->value = value; this->is_constant = true;}
~Symbol() {};
Symbol operator+(Symbol other){
if(this->is_constant & other.is_constant){
double value = this->value + other.value;
Symbol temp(value);
return temp;
}
Symbol temp;
temp.op = '+';
temp.left = this;
temp.right = &other;
return temp;
}
Symbol operator+(double other){
Symbol *temp = new Symbol(other);
if(this->is_constant){
double value = this->value + temp->value;
Symbol temp2(value);
return temp2;
}
Symbol temp2;
temp2.op = '+';
temp2.left = this;
temp2.right = temp;
return temp2;
// // uncomment below line and comment above function code and this will give segmentation fault
// return *this + *(new Symbol(other));
}
void print(){
if(this->is_expression){
std::cout left->print();
std::cout op right->print();
std::cout is_constant){
std::cout value
Подробнее здесь: [url]https://stackoverflow.com/questions/79470691/overloading-operator-in-c-for-symbol-class-and-avoiding-code-duplication[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия