ThreadPool and Threading.Timer?



我对线程中的计时器有疑问?

我的代码 :

public partial class Form1 : Form
{
    public Form1()
    {
        InitializeComponent();
    }
    private void Form1_Load(object sender, EventArgs e)
    {
       Testing testing = new Testing();           
       Thread thread = new Thread(new ThreadStart(delegate
        {
            testing.Start();               
        }));
        thread.IsBackground = true;
        thread.Start();
    }

}
public class Testing
{
    System.Threading.Timer timer = null;
    public void Start()
    {
        if (timer == null)
            timer = new System.Threading.Timer(timerTick, null, 500, 500);
        List<ManualResetEvent> amanual = new List<ManualResetEvent>();
        for (int index = 0; index < 10; index++)
        {
            ManualResetEvent manual = new ManualResetEvent(false);
            ThreadPool.QueueUserWorkItem(new WaitCallback(delegate(object context)
                {
                    this.RunningThreadPool(context);
                    manual.Set();
                }
                ));
            amanual.Add(manual);
        }
        WaitHandle.WaitAll(amanual.ToArray());
        Console.WriteLine("Task complete");
    }
    void timerTick(object sender)
    {            
        Console.WriteLine("Timer running");
    }
    public void RunningThreadPool(object context)
    {            
        Console.WriteLine("Thread in Threadpool is running...");           
    }
}

}

这就是结果线程池中的线程正在运行...线程池中的线程正在运行...线程池中的线程正在运行...线程池中的线程正在运行...线程池中的线程正在运行...线程池中的线程正在运行...线程池中的线程正在运行...线程池中的线程正在运行...线程池中的线程正在运行...线程池中的线程正在运行...任务完成计时器正在运行计时器正在运行计时器正在运行计时器正在运行

我有一个问题,计时器如何在线程池执行之前运行。除了在线程池上设置计时器。因为我需要线程池上的计时器检查线程。

我想说的是,在计时器触发一次之前,500 毫秒的时间足以完成您的工作队列。 10 次Console.WriteLine调用并不算太多工作。

假设您运行的工作负载稍重:

计时器在线程池中运行其回调,因此在其他工作排队后排队...即它在队列中的最后一个。由于排队的项目数多于线程池中的线程数,并且线程池仅在长时间负载下启动新线程,因此线程池无法及时执行计时器的回调。

最新更新