引用NuGet程序包库时,C#取消令牌花费的时间太长,无法触发

问题描述

我目前有一些代码通过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 (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...