Мне постоянно приходится писать синхронизированные службы Windows, которые опрашивают вне очередей или запускают синхронизированные процессы. Следовательно, у меня есть достаточно надежный шаблон для этого, но я нахожу, что каждый раз, когда я пишу сервис для этого, я начинаю с одного и того же шаблона, а затем пишу процесс внутри него.
Этим утром я задаюсь вопросом, могу ли я на самом деле превратить этот шаблон в структуру, в которую я мог бы внедрить свой процесс. Мой базовый шаблон - всего 122 строки кода. Из-за различий в требованиях к каждому процессу - то есть разного количества аргументов, разных типов аргументов и разных зависимостей (некоторые зависят от веб-служб, некоторые - от баз данных и т. Д.), Я не могу понять, как настроить базовый шаблон для получения Внедренный процесс.
Сердцем шаблона является просто таймер, который останавливается при инициализации и запуске процесса, а затем перезапускает таймер после завершения процесса. Затем я добавляю свой метод процесса и любые зависимости прямо в шаблон.
У кого-нибудь есть идеи, как это сделать? Я смотрел на внедрение зависимостей и часто уже использовал его для внедрения таких вещей, как подключение к хранилищу данных? Есть ли способ ввести делегата с неизвестным числом / типом параметров в класс? Я смотрю на это неправильно?
Это шаблон, который у меня есть:
TimedProcess.Template.cs
using System;
using System.Timers;
public partial class TimedProcess : IDisposable
{
private Timer timer;
public bool InProcess { get; protected set; }
public bool Running
{
get
{
if (timer == null)
return false;
return timer.Enabled;
}
}
private void InitTimer(int interval)
{
if (timer == null)
{
timer = new Timer();
timer.Elapsed += TimerElapsed;
}
Interval = interval;
}
public void InitExecuteProcess()
{
timer.Stop();
InProcess = true;
RunProcess();
InProcess = false;
timer.Start();
}
public void TimerElapsed(object sender, ElapsedEventArgs e)
{
InitExecuteProcess();
}
public void Start()
{
if (timer != null && timer.Interval > 0)
timer.Start();
}
public void Start(int interval)
{
InitTimer(interval);
Start();
}
public void Stop()
{
timer.Stop();
}
public TimedProcess()
: this(0)
{
}
public TimedProcess(int interval)
{
if (interval > 0)
InitTimer(interval);
}
private disposed = false;
public Dispose(bool disposing)
{
if (disposed || !disposing)
return;
timer.Dispose();
disposed = true;
}
public Dispose()
{
Dispose(true);
}
~TimedProcess()
{
Dispose(false);
}
}
TimedProcess.cs
using System;
public partial class TimedProcess
{
public void RunProcess()
{
//Hook process to run in here
}
}
Поэтому я хочу изменить его так, чтобы моя служба Windows порождала новый TimedProcess и внедряла его в процесс, который должен быть запущен, тем самым полностью удаляя код TimedProcess из моей службы Windows и ссылаясь на DLL.
Редактировать : Спасибо всем за помощь. Я понял, что если я вытолкну свой метод RunProcess () за пределы моей библиотеки TimedProcess и передам , что , в качестве действия в конструкторе, то это упростит все, что я искал:
[Упрощено для краткости]
public class TimedProcess
{
Action RunProcess;
Timer timer = new Timer();
private void TimerElapsed(object sender, ElapsedEventArgs e)
{
if (RunProcess != null)
RunProcess();
}
public TimedProcess(Action action, int interval)
{
timer.Interval = interval;
RunProcess = action;
timer.Start();
}
}