1.1让cpu 占用率曲线听你的指挥:
解法一:代码清单1-1
int main()
{
for(; ;
{
//CPU 一秒执行的次数
for(int i = 0; i <9600000; i++)
;
Sleep(10);
}
return 0;
}
解法二:代码清单1-2:
int busyTime =10; // 10 ms
int idleTime =busyTime; // same ratio will lead to50% cpu usage
Int64 startTime =0;
while(true)
{
startTime = GetTickCount();
// busy loop
while((GetTickCount() - startTime)<= busyTime)
;
// idle loop
Sleep(idleTime);
}
// C# code
static void MakeUsage(float level)
{
PerformanceCounter p = new PerformanceCounter("Processor", "%Processor Time","_Total");
if(p==NULL)
{
return
}
while(true)
{
if(p.NextValue() > level)
System.Threading.Thread.Sleep(10);
}
}
// C++ code to maketask manager generate sine graph
#include"Windows.h"
#include"stdlib.h"
#include"math.h"
const double SPLIT= 0.01;
const int COUNT =200;
const double PI =3.14159265;
const int INTERVAL= 300;
int _tmain(intargc, _TCHAR* argv[])
{
DWORD busySpan[COUNT]; // array of busy times
DWORD idleSpan[COUNT]; // array of idle times
int half = INTERVAL / 2;
double radian = 0.0;
for(int i = 0; i < COUNT; i++)
{
busySpan[i] = (DWORD)(half + (sin(PI * radian) * half));
idleSpan[i] = INTERVAL - busySpan[i];
radian += SPLIT;
}
DWORD startTime = 0;
int j = 0;
while(true)
{
j = j % COUNT;
startTime = GetTickCount();
while((GetTickCount() - startTime) <= busySpan[j])
;
Sleep(idleSpan[j]);
j++;
}
return 0;
}