c# - 让任务在控制台应用程序的后台永久运行
问题描述
我将从描述我想要实现的目标开始。这个想法是我有一个类的多个对象,它们有自己不同的计时器。当对象的计时器用完时,我希望该对象向控制台打印一条消息,然后重置计时器。我希望它在后台运行,以便我的应用程序可以在这些多个计时器在后台运行时继续工作。
例如像这样初始化(其中参数是以秒为单位的计时器):
BackGroundTimer timer1 = new BackGroundTimer(1);
BackGroundTimer timer2 = new BackGroundTimer(2);
BackGroundTimer timer3 = new BackGroundTimer(3);
Console.ReadLine();
Console.ReadLine() 象征着正在进行的工作。然后我希望有以下输出:
0:
1:定时器1
2:定时器 1 定时器 2
3:定时器 1 定时器 3
4:定时器 1 定时器 2
这有可能实现吗?
解决方案
看看Timer类。您可以在其构造函数中指定周期,它会定期调用指定的方法。
编辑:下面的代码示例
static void Main(string[] args)
{
Timer timer1 = new Timer(1000)
{
Enabled = true,
AutoReset = true
};
Timer timer2 = new Timer(2000)
{
Enabled = true,
AutoReset = true
};
Timer timer3 = new Timer(3000)
{
Enabled = true,
AutoReset = true
};
timer1.Elapsed += async (sender, e) => await HandleTimer("Timer1");
timer2.Elapsed += async (sender, e) => await HandleTimer("Timer2");
timer3.Elapsed += async (sender, e) => await HandleTimer("Timer3");
Console.ReadLine();
}
private static async Task HandleTimer(string message)
{
Console.WriteLine(message);
}
推荐阅读
- java - 为什么应用程序在启动时立即消失
- javascript - 未显示最大长度的验证消息
- azure - 如何在 Azure Pipelines 中使用外部文件进行 vstest
- database - Passing Dependent Selection Values in Laravel
- haskell - 常量的模式匹配
- laravel - laravel : get properti from function in same class and parsing to view
- excel - error while connecting to oracle db using oracle client. I am able to connect using ODBC data source administrator. But not in Excel VBA
- firebase - 无法再部署到 Firebase - “规则太多”
- jenkins - Conditional SVN checkout in Jenkins
- oracle - Restore oracle 9i db with dbf only (after shutdown abort)