编程之美 之 让CPU占用率听你指挥
昨天在bbs上淘到了这本编程之美。顺手刷了第一章,很有意思。第一章的要求是要控制CPU曲线,绘制出对应的形状。
拿到这个问题,我的第一反应是, 是不是有这么一个API,能在任务管理器上的对应区域直接绘制图形呢? 然后就去查找API, 可惜搜索能力不行,最终还是没有找到。
然后看书上的解释, 太棒了。
解决这道题目的核心是。 CPU占用率的概念,应该是指 CPU忙的时间与总时间的比,他是一个平均值的概念。也就是说。通过控制CPU忙闲时间的比值,我们能够大致控制CPU的占用率。
通过这个思想能够 控制CPU绘制各种我们想要的图形 >_<
方波
sin波
直线
源代码例如以下:
// ==================【控制cpu曲线】=================
// @ author : zhyh2010
// @ date : 20150609
// @ version : 1.0
// @ description : 核心: 在任务管理器的一个刷新周期内
// CPU 忙的时间 和 刷新时间的比率就是 CPU 的占用率
// CPU 显示的实际仅仅是一个平均值
// ================【end of 控制cpu曲线】===============
#include <stdlib.h>
#include <stdio.h>
#include <windows.h>
#include <math.h>
// void busy1()
// {
// for (int i = 0; i != 10; i++)
// {
// system("start calc");
// }
// system("taskkill /f /im calc.exe");
// printf("busy\n");
// }
void DrawSin()
{
system("title sin");
const float PI = 3.1415926535;
const int count = 360;
const int GAP = 1;
const DWORD totalTime = 200;
float x = 0;
float ratio[count] = { 0 };
for (int i = 0; i != count; i++, x += GAP)
ratio[i] = 0.5 * sin(PI * x / 180.0);
for (int i = 0; TRUE; i = (i + 1) % count)
{
DWORD startTime = GetTickCount();
while (GetTickCount() - startTime < (0.5 + ratio[i]) * totalTime);
Sleep((0.5 - ratio[i]) * totalTime);
}
}
void DrawLinear(float ratio = 0.9)
{
system("title drawline");
const DWORD totalTime = 200;
while (true)
{
DWORD startTime = GetTickCount();
while (GetTickCount() - startTime < ratio * totalTime);
Sleep((1 - ratio) * totalTime);
}
}
void DrawSquareWave(float max = 0.9, float min = 0.1)
{
system("title squareWave");
const DWORD totalTime = 200;
const int count = 300;
for (int i = 0; TRUE; i = (i + 1) % count)
{
float ratio = (i > count / 2) ? max : min;
DWORD startTime = GetTickCount();
while (GetTickCount() - startTime < ratio * totalTime);
Sleep((1 - ratio) * totalTime);
}
}
void main()
{
// ===============【设置进程所在cpu】=================
SetProcessAffinityMask(GetCurrentProcess(), 1);
DrawLinear();
//DrawSin();
//DrawSquareWave();
}
參考文章
编程之美:让CPU占用率曲线听你指挥
编程之美 之 让CPU占用率听你指挥的更多相关文章
- Shell编程检测监控mysql的CPU占用率
shell编程很强大! 网站访问量大的时候mysql的压力就比较大,当mysql的CPU利用率超过300%的时候就不能提供服务了,近乎卡死状态,这时候最好的方法就是重启mysql服务.由于这种事具有不 ...
- 编程之美_1.1 让CPU占用率曲线听你指挥
听到有人说让要写一个程序,让用户来决定Windows任务管理器的CPU占用率. 觉得很好奇.但第一个想法就是写个死循环.哈哈.不知道具体的占用率是多少,但至少能保证在程序运行时,CPU的占用率终会稳定 ...
- 编程之美读书笔记1.1——让CPU占用率曲线听你的指挥
http://blog.csdn.net/pipisorry/article/details/36189155 <strong><span style="font-size ...
- 《编程之美》学习笔记——指挥CPU占用率
问题: 写一个程序.让用户来决定Windows任务管理器(Task Manager)的CPU占用率(单核). 有下面几种情况: 1.CPU占用率固定在50%,为一条直线 2.CPU的占用率为一条直线, ...
- 让cpu占用率曲线听你指挥(多核处理器)
编程之美 1.1 让cpu占用率曲线听你指挥(多核处理器) [版权声明]转载请注明出处 http://www.cnblogs.com/TenosDoIt/p/3242910.html [目录] 不考 ...
- shell脚本检测监控mysql的CPU占用率
网站访问量大的时候mysql的压力就比较大,当mysql的CPU利用率超过300%的时候就不能提供服务了,近乎卡死状态,这时候最好的方法 就是重启mysql服务.由于这种事具有不可预见性,我们不知道什 ...
- 浅析 Pycharm 内存、cpu 占用率
浅析 Pycharm 内存.cpu 占用率 本机配置参数: ------------------------------------------ Windows 10 专业版 X64 ----- ...
- liteos CPU占用率(十六)
1. 概述 1.1 基本概念 CPU(中央处理器, Central Processing Unit)占用率可以分为系统CPU占用率和任务CPU占用率两种. 系统CPU占用率(CPU Percent)是 ...
- 查看Windows下引起Oracle CPU占用率高的神器-qslice
前言: qslice是一个win2000的工具包,能分析进程的cpu占用率,我们用于分析oracle的性能 这是绿色的软件无需安装. 我们经常会碰到oracle的CPU占用居高不下,无法快速定位到问题 ...
随机推荐
- Java sleep方法的作用(sleep())
sleep() 方法的作用是在指定的毫秒数内让当前“正在执行的线程”休眠(暂停执行).这个“正在执行的线程”是指 this.currentThread() 返回的线程. 例 1 下面通过一个案例来理解 ...
- 第1节 flume:4、离线项目处理的整个架构图;5、flume的基本介绍;
第1节 flume:4.离线项目处理的整个架构图 辅助系统工具:flume,azkaban,sqoop. 在一个完整的离线大数据处理系统中,除了hdfs+mapreduce+hive组成分析系统的核心 ...
- 前端学习日记-vue cli3.0环境搭建
卸载老版本的 vue-cli : npm uninstall vue-cli -g 安装新版本的 : npm install -g @vue/cli --安装新版本cli 同时nodeJS 要更新至 ...
- Openjudge-4132-四则运算表达式求值
这一题我们可以通过递归求解,首先我们可以把一个表达式分为三部分,分别是: (1)表达式 :项.加减 (2)项:因子.乘除 (3)因子:数.()表达式 这三项构成了递归的关系,我们可以看到,要求一个表达 ...
- 关于C/C++的一些思考(5)
运算符重载函数的限制: 五个不能实现重载的符号:".", ".*", "::", "?", "sizeof&q ...
- 洛谷 1196 [NOI2002]银河英雄传说【模板】带权并查集
[题解] 经典的带权并查集题目. 设cnt[i]表示i前面的点的数量,siz[i]表示第i个点(这个点是代表元)所处的联通块的大小:合并的时候更新siz.旧的代表元的cnt,路径压缩的时候维护cnt即 ...
- String字符串的遍历
StringTest.java /* * 变量字符串(获取字符串中的每一个字符) */ public class StringTest { public static void main(String ...
- URAL 1277 Cops and Thieves
Cops and Thieves Time Limit: 1000ms Memory Limit: 16384KB This problem will be judged on Ural. Origi ...
- 从Excel中读取数据(python-xlrd)
从Excel中读取数据(python-xlrd) 1.导入模块 import xlrd 2.打开Excel文件读取数据 data = xlrd.open_workbook('excelFile.xls ...
- POJ 2002 几何+hash
题目大意: 给定1000个点,寻找有多少组四点对能组成正方形 这里的题目跟上一道做的找平行四边形类似但想法却又不相同的方法 这里找任意2个点形成的一条边,那么可以根据这两个点,找到能和他们组成正方形剩 ...