首页 > 代码库 > 持续性任务代码的一些测试

持续性任务代码的一些测试

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),或者启动以个新的定时器