c#后台任务运行

在C#中如果想要执行一段一直运行的程序,如监听网络状态,实时读取PLC数据,遇到这种情况有多种解决方法。

方法一,可以起一个Task任务,在Task任务中写个死循环,这种死循环最好在最后写个 Thread.Sleep,不然程序会占用很高的CPU。

csharp 复制代码
//用于创建并启动任务的方法。它接受一个委托作为参数,该委托定义了任务要执行的代码
Task.Factory.StartNew(() =>
{
    while(true)
    {
        Console.WriteLine("一直运行的代码");
        Thread.Sleep(10);
    }
}, TaskCreationOptions.LongRunning);//选项:这是一个用于指定任务类型的选项。使用LongRunning选项可以告诉任务调度器,该任务是一个长时间运行的任务,从而使任务在一个单独的线程上执行。

方法二 System.Timers.Timer

csharp 复制代码
//定义Timer
System.Timers.Timer Timers_Timer = new System.Timers.Timer();
//手动设置Timer,开始执行
Timers_Timer.Interval = 20;
Timers_Timer.Enabled = true;
// AutoReset属性决定计时器是不是要发起一次事件然后停止,还是进入开始/等待的循环。
 Timers_Timer.AutoReset = true;
Timers_Timer.Elapsed += new System.Timers.ElapsedEventHandler(Timers_Timer_Elapsed); 
//一直运行的循环
void Timers_Timer_Elapsed(object sender, System.Timers.ElapsedEventArgs e)
{ 
Thread.Sleep(1000);
}
相关推荐
烛阴2 小时前
隐式vs显式:解密C#类型转换的底层逻辑
前端·c#
梦里不知身是客113 小时前
kafka作为Sink
c#·linq
猿来是你_L3 小时前
C# Dictionary 转换成 List
windows·c#·list
kokunka4 小时前
C#类修饰符功能与范围详解
java·开发语言·c#
mudtools4 小时前
.NET驾驭Excel之力:工作簿与工作表操作基础
c#·.net·excel
mudtools4 小时前
.NET驾驭Excel之力:单元格与区域操作详解
c#·.net·excel
用户8356290780517 小时前
C# 自动化生成 PowerPoint 演示文稿
后端·c#
饮品爱好者8 小时前
[C#] NO.4 我的第一个项目
vscode·职场和发展·c#·github
专注VB编程开发20年9 小时前
.net按地址动态调用VC++DLL将非托管DLL中的函数地址转换为.NET可调用的委托
开发语言·c++·c#·.net
玩泥巴的11 小时前
.NET驾驭Excel之力:工作簿与工作表操作基础
c#·excel·二次开发·office·com互操作