'poller' 类将从您创建的轮询线程中使用,因此您有一些选择。我可能会在轮询器类 ctor 中创建轮询线程 - 似乎没有理由让线程具有比这更大的范围。如果添加了更多设备,您需要做的就是创建更多轮询器实例。
在 OnStart() 中,创建一个 poller 实例(它自己创建 poller 线程)并返回,因此满足“OnStart-Event 不应永远执行”条件。
在 OnStop() 中停止线程?首先,尝试停止线程的首选方法 - 根本不要尝试这样做。从服务管理器或任务管理器关闭时,您的服务是否运行正常并立即停止?如果是这样,不要通过尝试在 OnStop() 或轮询器类 dtor 中显式停止轮询线程来进行不必要的工作,并且可能会适得其反。只需将 OnStop() 留空,看看它是否工作正常。
如果你发现你必须在服务进程被操作系统杀死之前终止一个线程,你可能不得不采取狡猾的手段来说服轮询线程立即退出,或者你可能会使用 Thread.Interrupt() 侥幸逃脱。依靠..
只是为了看看,我试过这个:
class poller
{
public static void ThreadProc()
{
for (;;)
{
Thread.Sleep(0);
}
}
Thread myThread;
public poller(){
myThread = new Thread(new ThreadStart(ThreadProc));
myThread.Priority = ThreadPriority.BelowNormal;
myThread.Start();
}
};
class WindowsService : ServiceBase
{
poller thisPoller;
public WindowsService()
{
this.ServiceName = "My Windows Service";
this.EventLog.Log = "Application";
this.CanHandlePowerEvent = true;
this.CanHandleSessionChangeEvent = true;
this.CanPauseAndContinue = true;
this.CanShutdown = true;
this.CanStop = true;
}
protected override void OnStart(string[] args)
{
base.OnStart(args);
thisPoller = new poller();
}
protected override void OnStop()
{
base.OnStop();
}
在修改了一些项目属性并运行了正确版本的 installUtil 之后,它构建并安装好了。它开始正常,sleep(0) 循环显然正在工作,因为该服务出现在“进程”选项卡上,我的 i7 上的 CPU 使用率约为 17%。当我在任务管理器服务上选择“停止服务”时,服务状态立即变为“已停止”,但是该进程消失了大约 20 秒,(?)。
为了更有趣,我真的把盒子装满了。我停止了服务,卸载并重建:
protected override void OnStart(string[] args)
{
base.OnStart(args);
thisPoller = new poller();
thisPoller = new poller();
thisPoller = new poller();
thisPoller = new poller();
thisPoller = new poller();
thisPoller = new poller();
thisPoller = new poller();
thisPoller = new poller();
}
当我重新安装并重新启动时,我知道它正在工作,因为我可以在进入任务管理器之前听到 CPU 风扇转动的声音。果然,所有 8 个核心 100%。
即使有 8 个 CPU 循环线程,停止也没有问题。同样,状态立即变为“已停止”,该过程在 20 秒后消失。
将睡眠间隔设置为“1000000”以便线程不运行也没有任何问题 - 开始正常,停止正常。