玩转CPU运行曲线
Leaf
是不是从来没有想过看看cpu运行曲线啊骚年?顶多也就仅仅是看看cpu利用率,吓自己一跳后感觉关闭几个不该打开的程序~
然而问题来了,微软公司要让你绘制cpu运行曲线啊!!不仅是固定的直线,还要绝对值函数,还有正弦!!我的天这游戏还能玩?
Require
写一个程序,让用户来决定Windows任务管理器(Task Manager)的CPU占用率。程序越简越好,计算机语言不限。例如,可以实现下面三种情况:
- CPU的占用率固定在50%,为一条直线
- CPI的占用率为一条直线,但是具体占用率由命令行参数决定(参数范围1~100)
- CPU的占用率状态是一个正弦曲线
Analysis
若不小心写了一个死循环,CPU的占用率就会跳到最高,并且一直保持在100%。我们也可以打开任务管理器,实际观察一下它是怎样变动的。凭肉眼观察,它大约是1秒钟更新一次。一般情况下,CPU使用率会很低。但是当一个用户运行一个程序,执行一些复杂操作的时候,CPU的使用率会急剧升高。当用户晃动鼠标时,CPU的使用率也会有小幅度的变化。
当任务管理器报告的CPU使用率为0的时候,谁在使用CPU呢?通过任务管理器的进程(Process)一栏可以看到,System Idle Process占用了CPU的空闲的时间。系统中有那么多进程,它们什么时候能“闲下来”呢?答案很简单,这些程序或在等待用户的输入,或在等待某些事件的发生,或者主动进入休眠状态。
在任务管理器的一个刷新周期内,CPU忙(执行应用程序)的时间和刷新周期总时间的比率,就是CPU的占用率,也就是说,任务管理器中显示的是每个刷新周期内CPU占用率的统计平均值。因此,我们可以写一个程序,让它在任务管理器的刷新期间内一会忙,一会闲,然后通过调节忙/闲的比例,就可以控制任务管理器中显示的CPU占用率。
Solution
此处提供4种解法
【解法一】简单的解法
通过Busy loop() ,Sleep()来操作CPU的使用率曲线
需要了解的知识
http://blog.csdn.net/zhandoushi1982/article/details/6101515 http://blog.csdn.net/phunxm/article/details/9013535#include <windows.h>
int main()
{
for ( ; ; )
{
for ( int i= 0; i < 4000000000; i++) // 循环次数由具体cpu决定
;
Sleep(10); // 看上面网址里的内容哟~
}
return 0;
}
【解法二】使用GetTickCount(()和Sleep()
通俗易懂,没什么好解释的,不懂的话就绝望吧,绝望一会就OK了
#include <windows.h>
int main()
{
int busyTime = ; // 10 ms
int idleTime = busyTime; // same ratio willlead to 50% cpu usage _int64 startTime = ,middleTime = ;
while(true)
{
startTime = GetTickCount ();
// busy loop
while (((middleTime=GetTickCount ()) - startTime) <= busyTime)
; // idle loop
Sleep(idleTime);
}return ;
}
【解法三】能动态适应的算法
因为注释着C#,所以我就并不想去理它了。额,对了,它用了Microsoft.Net Framework 提供的PerformanceCounter对象,不懂就去百度吧~
static void MakeUsage(float level)
{
PerformanceCounter p = new PerformanceConter("Processor", "% ProcessorTime", "_Total"); while(true)
{
if(p.NextValue() > level)
Sysem.Threading.Thread.Sleep();
}
}
【解法四】正弦曲线
好了,认真学完前三个的乖同学现在已经能编CPU的正弦曲线啦(不能的话我也帮不了你了。。原谅我括号里面打省略号。。)
现在直接上代码吧!!
#include "Windows.h"
#include "stdlib.h"
#include "math.h" const double SPLIT = 0.01;
const int COUNT = ;
const double PI = 3.14159265;
const int INTERVAL = ; int main()
{
DWORD busySpan[COUNT]; // array of busy times
DWORD idleSpan[COUNT]; // array of idle times
int half = INTERVAL / ;
double radian = 0.0;
for ( int i = ; i < COUNT; i++)
{
busySpan[i] = (DWORD)(half + (sin(PI * radian) * half));
idleSpan[i] = INTERVAL - busySpan[i];
radian += SPLIT;
} DWORD startTime = ;
int j = ;
while(true)
{
j = j % COUNT;
startTime = GetTickCount();
while((GetTickCount() - startTime) <= busySpan[j])
;
Sleep(idleSpan[j]);
j++; }
return ;
}
复制代码好玩吗?啊?哈哈哈,是不是觉得为什么我没有正弦曲线啊?这些方法并没有什么卵用,是不是这样觉得?其实是有用的,我不会告诉你的。有问题欢迎讨论
附上江湖代码一份
原址
http://www.cnblogs.com/Ripper-Y/archive/2012/05/19/2508511.html#include <iostream>
#include <cmath>
#include <ctime>
#include <windows.h> using namespace std; //得到循环0xFFFFFFFF次用的秒数
unsigned int test()
{
unsigned int c = 0xFFFFFFFF; time_t t1, t2;
time(&t1); for(unsigned int i = ; i < c; i++)
;
time(&t2);
return (unsigned int)(t2 -t1); } #define T 20000 //周期时间 20秒
#define C 100 //采样点时间间隔
#define PI 3.1415 //PI
const unsigned int count = 0xFFFFFFFF / (test() *); //采样间隔可以执行的循环数目
const unsigned int N = T/C; //周期内采样点数目
unsigned int v[N] = { }; //所有采样点连续执行循环数
unsigned int mt[N] = { }; //所有采样点休眠毫秒数 int main()
{
//计算循环次数和休眠时间
for(int i = ; i < N; i++)
{
double x = * PI * i / N;
double r = (sin(x) + ) / ; mt[i] = C - r * C;
v[i] = r * C * count;
}
for(;;)
{
for(int i = ; i < N; i++)
{
for(int j = ; j < v[i]; j++)
;
Sleep(mt[i]);
}
}
return ;
}
Tree
第一节是关于硬件的知识,要学的东西真不少。对了,最近决定要学习Html+Css和数据加密所以我会非常忙!!其实我自己都不信。。好咯大概就是这么多咯,写着真累。整篇文章全手打,摘自编程之美~

玩转CPU运行曲线的更多相关文章
- [C++]让CPU使用率曲线呈现为正弦曲线(一)
看<编程之美>的第一题就很有意思: 写一个程序,让用户来决定Windows任务管理器的CPU占用率.可以实现下面三种情况: 1. CPU的占用率固定在50%,为一条直线: 2. CPU的占 ...
- 深入理解 Linux Cgroup 系列(二):玩转 CPU
原文链接:深入理解 Linux Cgroup 系列(二):玩转 CPU 上篇文章主要介绍了 cgroup 的一些基本概念,包括其在 CentOS 系统中的默认设置和控制工具,并以 CPU 为例阐述 c ...
- 【转】多核CPU运行模式
多核CPU运行模式主要有以下三种: •非对称多处理(Asymmetric multiprocessing,AMP)——每个CPU内核运行一个独立的操作系统或同一操作系统的独立实例(instantiat ...
- Keras/Tensorflow选择GPU/CPU运行
首先,导入os,再按照PCI_BUS_ID顺序,从0开始排列GPU, import os os.environ["CUDA_DEVICE_ORDER"] = "PCI_B ...
- Process和Thread在指定CPU运行
最近帮朋友写了一个多线程程序,他那边一运行多线程就出错,我这边却没有任何问题,找了好久才找到解决方法,原来是CPU的问题,有朋友遇到同样的问题,可以一起参考 //进程与指定cpu绑定 SetProce ...
- ubuntu16.04下caffe以cpu运行faster rcnn demo
参考https://haoyu.love/blog404.html 获取并修改代码 首先,我们需要获取源代码: git clone --recursive https://github.com/rbg ...
- 玩转CPU之直线
近期在看编程之美,看到第一个问题时,一下子就被吸引了,原来在windows 的任务管理器中还能够让CPU舞动起来,再一次的相信了编程中仅仅有想不到没有做不到,对于书中的做法和网上的实现大致都同样.只是 ...
- GPU版TensorFlow怎么指定让CPU运行
由于某些原因GPU版的TensorFlow运行起来会出现一些问题,比如内存溢出等情况.此时我们可以用CPU和系统内存来运行我们的程序. 代码如下: import osos.environ[" ...
- 软硬件协同编程 - C#玩转CPU高速缓存(附示例)
写在前面 好久没有写博客了,一直在不断地探索响应式DDD,又get到了很多新知识,解惑了很多老问题,最近读了Martin Fowler大师一篇非常精彩的博客The LMAX Architecture, ...
随机推荐
- Posting array of JSON objects to MVC3 action method via jQuery ajax
Does the model binder not suport arrays of JSON objects? The code below works when sending a single ...
- UVA11324 The Largest Clique —— 强连通分量 + 缩点 + DP
题目链接:https://vjudge.net/problem/UVA-11324 题解: 题意:给出一张有向图,求一个结点数最大的结点集,使得任意两个结点u.v,要么u能到达v, 要么v能到达u(u ...
- POJ1177 Picture —— 求矩形并的周长 线段树 + 扫描线 + 离散化
题目链接:https://vjudge.net/problem/POJ-1177 A number of rectangular posters, photographs and other pict ...
- wirte function in powershell
https://github.com/dahlbyk/posh-git/blob/master/src/Utils.ps1#L102 https://docs.microsoft.com/en-us/ ...
- NPU 2015年陕西省程序设计竞赛网络预赛(正式赛)F题 和谐的比赛(递推 ||卡特兰数(转化成01字符串))
Description 今天西工大举办了一场比赛总共有m+n人,但是有m人比较懒没带电脑,另外的n个人带了电脑.不幸的是,今天机房的电脑全坏了只能用带的电脑,一台电脑最多两人公用,确保n>=m. ...
- 小程序-demo:小程序示例
ylbtech-小程序-demo:小程序示例 1.返回顶部 0. 1.app.js const openIdUrl = require('./config').openIdUrl App({ ...
- Mysql数据库的用户和日志管理
Mysql数据库的用户和日志管理 数据库的用户管理 1.mysql用户账号管理 用户账号 user@host user:账户名称 host:此账户可通过哪些客户端主机请求创建连接线程,可以是ip.主机 ...
- Codeforces Round #386 (Div. 2)G. New Roads [构造][树]
题目链接:G. New Roads 题意:给出n个结点,t层深度,每层有a[i]个结点,总共有k个叶子结点,构造一棵树. 分析: 考虑一颗树,如果满足每层深度上有a[i]结点,最多能有多少叶子结点 那 ...
- springboot(七) 配置嵌入式Servlet容器
github代码地址:https://github.com/showkawa/springBoot_2017/tree/master/spb-demo/spb-brian-query-service ...
- 版本管理工具SVN的使用
一.安装服务器端和客户端 需要的软件: 1.服务器端:SlikSVN,下载传送门:http://www.sliksvn.com/en/download/ 2.客户端:“乌龟”,下载传送门:http:/ ...