Назад к вопросам
Senior
7
В чём основная проблема выбранной структуры решения Класс Property не поддерживает полиморфизм Поля класса могут быть неинициализированы Метод переноса расчета общей стоимости в классе «Заказ» Не использует механизмы транзакционности Нет исключений при пустом спискеpublic class RealEstateService { private ListingRepository listingRepository; public RealEstateService(ListingRepository listingRepository) { this.listingRepository = listingRepository; } public double calculateTotalCost() { List<Property> properties = listingRepository.getAllListings(); double total = 0; for (Property property : properties) { total += property.getPrice(); } return total; } } class ListingRepository { public List<Property> getAllListings() { return Arrays.asList(new Property(250000), new Property(150000)); } } class Property { private double price; public Property(double price) { this.price = price; } public double getPrice() { return price; } }
Компании, где спрашивали
СБК ПАРУС
Ответ от нейросети
sobes.tech AI
Основная проблема в том, что класс Property не поддерживает полиморфизм. В текущей реализации все объекты Property имеют одинаковую структуру и поведение, что ограничивает расширяемость и гибкость.
Если в будущем появятся разные типы недвижимости с разными способами расчёта цены или дополнительными свойствами, текущая структура не позволит это удобно реализовать.
Для улучшения стоит сделать Property абстрактным классом или интерфейсом, а конкретные типы недвижимости реализовать как подклассы. Тогда метод getPrice() можно переопределять для разных типов.
Пример:
abstract class Property {
public abstract double getPrice();
}
class Apartment extends Property {
private double basePrice;
private double maintenanceFee;
public Apartment(double basePrice, double maintenanceFee) {
this.basePrice = basePrice;
this.maintenanceFee = maintenanceFee;
}
@Override
public double getPrice() {
return basePrice + maintenanceFee;
}
}
class House extends Property {
private double price;
public House(double price) {
this.price = price;
}
@Override
public double getPrice() {
return price;
}
}
Это позволит расширять модель без изменения существующего кода и использовать полиморфизм для расчёта стоимости.