У меня есть проблема, для которой я пытался получить помощь раньше, но я не смог ее решить тогда, поэтому я пытаюсь упростить проблему сейчас, чтобы посмотреть, смогу ли я получить более конкретную помощь с это потому что это сводит меня с ума ...
По сути, у меня есть рабочая (более сложная) версия этого приложения, которая является калькулятором стоимости проекта. Но поскольку в то же время я пытаюсь научиться лучше проектировать свои приложения, я хотел бы получить некоторую информацию о том, как я могу улучшить этот дизайн. В основном, главное, что я хочу - это вводить условия, которые (здесь) повторяются в двух местах. Предложения, которые я получил раньше, заключались в использовании стратегии или фабричной модели. Я также знаю о книге Мартина Фаулера с предложением Refactor, обусловленным полиморфизмом. Я понимаю этот принцип в его более простом примере. Но как я могу сделать одну из этих вещей здесь (если таковая будет подходящей)? На мой взгляд, расчет зависит от нескольких условий: 1. Что это за услуга, написание или анализ? 2. Проект маленький, средний или большой? (Обратите внимание, что могут быть и другие параметры, одинаково разные, например, «продукты новые или ранее существовали?». Поэтому такие параметры можно добавить, но я постарался сделать пример простым, используя только два параметра. возможность получить конкретную помощь)
То есть рефакторинг с полиморфизмом подразумевал бы создание ряда подклассов, которые у меня уже есть для первого условия (типа обслуживания), и действительно ли мне нужно создавать больше подклассов для второго условия (размера)? Что бы это стало, AnalysisSmall, AnalysisMedium, AnalysisLarge, WritingSmall и т.д… ??? Нет, я знаю, что это нехорошо, я просто не понимаю, как работать с этим шаблоном?
Я вижу ту же проблему в основном для предложений по использованию шаблона стратегии (и, как я вижу, заводской шаблон, он будет просто помощником для достижения указанного выше полиморфизма). Поэтому, пожалуйста, если у кого-то есть конкретные предложения относительно того, как спроектировать эти классы наилучшим образом, я был бы очень благодарен! Пожалуйста, также подумайте, правильно ли я выбрал объекты, или их нужно переделать. (Ответы типа «Вы должны рассмотреть фабричный шаблон», очевидно, не будут полезны ... Я уже шел по этому пути, и я в тупик, как именно в этом случае)
С уважением,
Anders
Код (очень упрощенный, не обращайте внимания на тот факт, что я использую строки вместо перечислений, не использую файл конфигурации для данных и т. Д., Что будет сделано по мере необходимости в реальном приложении, как только я получу представление о эти проблемы дизайна):
public abstract class Service
{
protected Dictionary<string, int> _hours;
protected const int SMALL = 2;
protected const int MEDIUM = 8;
public int NumberOfProducts { get; set; }
public abstract int GetHours();
}
public class Writing : Service
{
public Writing(int numberOfProducts)
{
NumberOfProducts = numberOfProducts;
_hours = new Dictionary<string, int> { { "small", 125 }, { "medium", 100 }, { "large", 60 } };
}
public override int GetHours()
{
if (NumberOfProducts <= SMALL)
return _hours["small"] * NumberOfProducts;
if (NumberOfProducts <= MEDIUM)
return (_hours["small"] * SMALL) + (_hours["medium"] * (NumberOfProducts - SMALL));
return (_hours["small"] * SMALL) + (_hours["medium"] * (MEDIUM - SMALL))
+ (_hours["large"] * (NumberOfProducts - MEDIUM));
}
}
public class Analysis : Service
{
public Analysis(int numberOfProducts)
{
NumberOfProducts = numberOfProducts;
_hours = new Dictionary<string, int> { { "small", 56 }, { "medium", 104 }, { "large", 200 } };
}
public override int GetHours()
{
if (NumberOfProducts <= SMALL)
return _hours["small"];
if (NumberOfProducts <= MEDIUM)
return _hours["medium"];
return _hours["large"];
}
}
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
List<int> quantities = new List<int>();
for (int i = 0; i < 100; i++)
{
quantities.Add(i);
}
comboBoxNumberOfProducts.DataSource = quantities;
}
private void comboBoxNumberOfProducts_SelectedIndexChanged(object sender, EventArgs e)
{
Service writing = new Writing((int) comboBoxNumberOfProducts.SelectedItem);
Service analysis = new Analysis((int) comboBoxNumberOfProducts.SelectedItem);
labelWriterHours.Text = writing.GetHours().ToString();
labelAnalysisHours.Text = analysis.GetHours().ToString();
}
}