首页 > 代码库 > 持续性任务代码的一些测试
持续性任务代码的一些测试
using System;using System.Collections.Generic;using System.Collections.Concurrent;using System.ComponentModel;using System.Data;using System.Drawing;using System.Linq;using System.Text;using System.Windows.Forms;using System.Threading;namespace CallTest{ public partial class Form1 : Form { private ConcurrentQueue<String> _Queue = new ConcurrentQueue<string>(); public Form1() { InitializeComponent(); } private void button1_Click(object sender, EventArgs e) { //var c = new CallT(); //c.DoWork(); Thread t1=new Thread(()=>{OutQueue();}); t1.IsBackground = true; t1.Start(); var arr = new List<Thread>(); for (int i = 0; i < 50; i++) { arr.Add( new Thread(() => { EnQueue(); })); } arr.ForEach((ent) => ent.Start()); } private void EnQueue() { for (int i = 0; i < 1000; i++) { string msg = string.Format("Id:{0},Index:{1}",Thread.CurrentThread.ManagedThreadId,i); _Queue.Enqueue(msg); Thread.Sleep(10); } } private void OutQueue() { int i = 0; while (true) { if (_Queue.Count > 0) { i++; string msg = null; //Console.WriteLine(_Queue.Dequeue(); + " Count:" + i);//这里使用Queue时会出现记录丢失等情况 if (_Queue.TryDequeue(out msg)) { Console.WriteLine(msg + " Count:" + i); } } // Thread.Sleep(10); } } } public class CallT { private bool Enable { get; set; } public CallT() { Enable = false; } private void _DoWork() { try { Thread.Sleep(100); Console.WriteLine("TId:" + Thread.CurrentThread.ManagedThreadId); } catch (Exception ex) { } finally { if (Enable) { //ThreadPool.QueueUserWorkItem((o) => { // _DoWork(); //}); //使用Thead时会出现缓慢的内存泄漏所以需要使用ThreadPool System.Threading.Timer t = null; using( t = new System.Threading.Timer((o) => { _DoWork(); }, null, 0, 0); Thread.sleep(10);//需要一定时间以让timer触发 防止被直接回收 } } } } public void DoWork() { Enable = true; _DoWork(); } }}
当需要一个任务持续进行时,可以在任务退出时启动一个新的线程(使用ThreadPool),或者启动以个新的定时器
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。