任务/线/委托.beginInvoke with Thread.Sleep()
本文关键字:Sleep Thread beginInvoke 委托 任务 with | 更新日期: 2023-09-27 18:04:42
在下面的示例中,只有_DisplayUsingThreads(timesToDisplay)真正并行执行操作。而另外两个_DisplayUsingTasks和_displayusingdelegate一次只执行4个任务(在四核机器上),然后等待一秒钟再执行4个任务。为什么?
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
delegate void DisplayDelegate();
DisplayDelegate myDisplaySleep;
private void btnGo_Click(object sender, EventArgs e)
{
const int timesToDisplay = 50;
//_DisplayUsingDelegates(timesToDisplay);
//_DisplayUsingTasks(timesToDisplay);
//_DisplayUsingThreads(timesToDisplay);
}
private void _DisplayUsingTasks(int displayNumber)
{
for (int i = 0; i < displayNumber; i++)
{
Task task = new Task(DisplayIdSleep);
task.Start();
}
}
private void _DisplayUsingThreads(int displayNumber)
{
for (int i = 0; i < displayNumber; i++)
{
Thread thread = new Thread(DisplayIdSleep);
thread.Start();
}
}
private void _DisplayUsingDelegates(int displayNumber)
{
myDisplaySleep = DisplayIdSleep;
for (int i = 0; i < displayNumber; i++)
{
myDisplaySleep.BeginInvoke(null, null);
}
}
private void DisplayIdSleep()
{
Debug.WriteLine("Thread Id : {0}", Thread.CurrentThread.ManagedThreadId);
Thread.Sleep(1000);
}
}
这是Task
和BeginInvoke
使用线程池线程的结果,而创建您自己的线程,则创建一个线程。
将ThreadPool.SetMinThreads(50, 0);
加入btnGo_Click
,观察结果
可以排队到线程池的操作数量仅受可用内存的限制;但是,线程池限制了进程中可以同时活动的线程数量。从。net Framework 4开始,进程线程池的默认大小取决于几个因素,比如虚拟地址空间的大小。