问题描述
我目前有一些代码通过NuGet包依赖项引用项目库。如果有什么不同,此NuGet软件包将托管在我们创建的其中一台NuGet服务器上,我目前将其用作NuGet源而不是nuget.org。
比方说,我从NuGet包中调用方法的类称为ClassA,并且具有以下代码:
public class ClassA {
// a bunch of code that sets up the configuration
// call to a periodic transmitter method from the nuget library file
PeriodicTransmitter transmitter = new PeriodicTransmitter(cancellationTokenSource);
transmitter.Start();
stoppingToken.WaitHandle.WaitOne();
periodicTransmitter.Stop();
}
然后,在NuGet包中引用的PeriodicTransmitter文件中,存在一个由取消令牌控制的循环:
public class PeriodicTransmitter {
private CancellationTokenSource _cancellationTokenSource = new CancellationTokenSource();
public PeriodicTransmitter(CancellationTokenSource cancellationTokenSource)
{
_cancellationTokenSource = cancellationTokenSource;
}
while(!_cancellationTokenSource.Token.IsCancellationRequested) {
logger.Loginformation("some info");
// operating code
logger.Loginformation("more info");
}
}
操作代码工作正常,但是当我在控制台中按ctrl + c终止程序时,令牌触发之前会有大约5-6秒的延迟。操作代码只是不断循环几次,并在停止之前记录所有正确的信息。在非常相似的情况下,我已经多次使用取消令牌,但从未遇到过这个问题。
我通过将库方法粘贴到我的工作文件中而不是引用NuGet包进行了实验,问题神奇地消失了。一旦我尝试终止程序,我的令牌就会立即正确触发,但这不是我想要的。我仍然希望能够引用NuGet程序包。
任何帮助或建议将不胜感激。谢谢!
编辑:问题是我不小心初始化了PeriodicTransmitter类中的字段值_cancellationTokenSource。删除后,控制台应用程序终止得更快。感谢@Wyck提供解决方案。
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)