System.Threading.Timerタイマ停止(失効)問題解決方法
一、現象
WebAPIプロジェクトのメソッドTools()でタイマーを使用する
IISに配備すると、タイマは常に無効であり、正確には1秒に1回実行されていないことがわかります.
二、探究
timerは局所変数と初歩的に考えられ,一つの方法のライフサイクルが終了した後にtimerが回収された.
timerをクラスメンバー変数に変更し、静的変数と書きます.
発見は依然として問題があり、その後、この方法は
WebApiConfig.csのRegisterメソッドのnewのクラス、このクラスはこのメソッドの終了に伴い、リソース回収される可能性があります!
元のコードは次のとおりです.
改変コード
これでタイマーは正常に動作します.
WebAPIプロジェクトのメソッドTools()でタイマーを使用する
var timer = new System.Threading.Timer((unused) =>
{
Console.WriteLine("1");
}, null, 0, 1000);//1
IISに配備すると、タイマは常に無効であり、正確には1秒に1回実行されていないことがわかります.
二、探究
timerは局所変数と初歩的に考えられ,一つの方法のライフサイクルが終了した後にtimerが回収された.
timerをクラスメンバー変数に変更し、静的変数と書きます.
static System.Threading.Timer timer = null;
発見は依然として問題があり、その後、この方法は
WebApiConfig.csのRegisterメソッドのnewのクラス、このクラスはこのメソッドの終了に伴い、リソース回収される可能性があります!
元のコードは次のとおりです.
public static class WebApiConfig
{
public static void Register(HttpConfiguration config)
{
var tool = new Tools();
tool.Run();
}
}
改変コード
public static class WebApiConfig
{
static Tools tool = new Tools();
public static void Register(HttpConfiguration config)
{
tool.Run();
}
}
これでタイマーは正常に動作します.