BotFactory, как можно догадаться из названия, – фабрика роботов. Подавляющее большинство объектов, используемое нами в реальном мире, так или иначе производятся на специально оборудованных для этого площадях, называемых заводами, фабриками, производствами и так далее. Так же и в OsEngine созданием экземпляров торговых роботов занимается специально созданный для этого объект.
Код класса расположен в файле BotFactory.cs в каталоге OsEngine\project\OsEngine\Robots\
Рис. 1. Расположение класса BotFactory в проекте.
Класс BotFactory инкапсулирует всю логику создания роботов в одном месте, но «заставить» фабрику иметь возможность создавать экземпляры роботов можно тремя способам:
В последующих статьях мы подробнее поговорим о каждом из этих способов.
Рассмотрим все члены класса BotFactory:
BotsWithAttribute – приватное статическое поле только для чтения. Содержит словарь, в качестве ключа в котором выступает имя типа робота, в качестве значения – ссылка на объект-тип класса робота.
GetNamesStrategy – общедоступный статический метод. Возвращает список имен роботов, которые создаются классическим способом и при помощи атрибута класса.
GetStrategyForName – публичный статический метод. Инкапсулирует логику создания роботов классическим способом и при помощи атрибута класса. Принимает следующие параметры:
GetTypesWithBotAttribute – приватный статический метод. Инициализирует поле BotsWithAttribute.
GetScriptsNamesStrategy – публичный статический метод. Возвращает список имен роботов, которые создаются путем загрузки из файлов в виде скриптов.
GetFullNamesFromFolder – приватный статический метод. Возвращает список строк с указанием пути к коду скриптов.
CreateScriptStrategyByName – публичный статический метод. Инкапсулирует логику создания экземпляров роботов из файлов скриптов. Принимает следующие параметры:
Serialize – приватный статический метод. Генерирует, затем компилирует код скрипта из файла.
GetDllsPathFromFolder – приватный статический метод. Возвращает путь к dll библиотекам, которые необходимы для компиляции кода скрипта.
ReadFile – приватный статический метод. Считывает по заданному пути код из текстового файла.
GetNamesStrategyWithParametersSync – публичный статический метод. Используется оптимизатором, синхронизирует процесс получения списка имен классов роботов, которые имеют оптимизируемые параметры.
NeadToReload – публичное статическое поле типа bool. Флаг, указывающий на необходимость перезагрузки списка с именами классов роботов.
LoadBotsNames – приватный статический метод. Загружает в переменную список имен роботов, имеющих оптимизируемые параметры.
SaveBotsNames – приватный статический метод. Сохраняет в хранилище список имен роботов, имеющих оптимизируемые параметры.
LoadNamesWithParam – приватный статический метод. Сохраняет в переменную список имен классов роботов, которые имеют оптимизируемые параметры.
LoadNamesWithParamEndEvent – общедоступное статическое событие. Извещает подписчиков о готовности списка ботов с параметрами.
Комментарии