多线程为什么会卡

今天写了一个测试多线程的程序,线程函数如下所示:

UINT ThreadFunction(LPVOID lp)
{
int i,j,k;
int a;
for(i=0;i<=1000;i++)//ºÄʱ
for(j=0;j<=1000;j++)
for(k=0;k<=1000;k++)
{
a=i+j+k;
}
AfxMessageBox("多线程运算结束");
return 0;
}

发现当同时打开打开多个这样的线程时,界面就会显得很卡,当打开一个就不会卡。

问了一些人他们说,for循环太多,导致程序太卡,将for循环减少循环嵌套为一个时发现不卡(因为线程瞬间执行完了),但如果这样如何让线程来执行耗时任务呢?

上网搜了一下线程调度和管理的资料(具体参见操作系统),知道线程调度的基本规律:

1.线程会一直或大部分时间执行高优先级的线程。

2.有多个同等优先级的线程就会按CPU时间片进行循环执行。


而我的程序各个线程的优先级是相同的,这样来看,界面卡的原因不是for循环太多,而是线程个数太多,当时有个哥们给我说建立一个线程池,别运行那么多的线程,现在看来是对的。但为什么线程多了就卡?因为对于相同优先级的线程,cpu时间以时间片为单位循环执行各个线程,因为我们的线程函数需要一定的时间因此会花掉整个cpu的时间片,假设同时打开5个这样的线程,再加上1个主线程。也就是说主线程会每6*时间片的时间才会执行一次,这样的话主线程得到cpu的时间会较少,界面会显得很卡。

因此,可以减少线程运行的个数,或者降低工作线程的优先级。

你可能感兴趣的:(多线程为什么会卡)