其实就是做个实验,看看SetPriorityClass是否真的会生效。

设计思路:主线程一直在进行某种操作(这里是写文件操作),以保证有一定的CPU占用率;生成的子线程来接收你的命令,决定将进程改变为什么级别。

代码逻辑如下:

#include <iostream>
#include <windows.h>
#include <tchar.h>
#include <process.h>
#include <fstream> using namespace std;
unsigned int WINAPI ThreadFunc(PVOID pvParam){
HANDLE hPThread = (HANDLE)pvParam;
printf("Enter thread\n");
while (true){
char cPriority = getchar();
//SuspendThread(hPThread);
if (cPriority == 'a')
{
if (!SetPriorityClass(GetCurrentProcess(), IDLE_PRIORITY_CLASS))
{
printf("SetPriorityClass failed:%d\n", GetLastError());
return FALSE;
}
printf("IDLE_PRIORITY_CLASS\n");
}
if (cPriority == 'b')
{
if (!SetPriorityClass(GetCurrentProcess(), BELOW_NORMAL_PRIORITY_CLASS))
{
printf("SetPriorityClass failed:%d\n", GetLastError());
return FALSE;
}
printf("BELOW_NORMAL_PRIORITY_CLASS\n");
}
if (cPriority == 'c')
{
if (!SetPriorityClass(GetCurrentProcess(), NORMAL_PRIORITY_CLASS))
{
printf("SetPriorityClass failed:%d\n", GetLastError());
return FALSE;
}
printf("NORMAL_PRIORITY_CLASS\n");
}
if (cPriority == 'd')
{
if (!SetPriorityClass(GetCurrentProcess(), ABOVE_NORMAL_PRIORITY_CLASS))
{
printf("SetPriorityClass failed:%d\n", GetLastError());
return FALSE;
}
printf("ABOVE_NORMAL_PRIORITY_CLASS\n");
}
if (cPriority == 'e')
{
if (!SetPriorityClass(GetCurrentProcess(), HIGH_PRIORITY_CLASS))
{
printf("SetPriorityClass failed:%d\n", GetLastError());
return FALSE;
}
printf("HIGH_PRIORITY_CLASS\n");
}
if (cPriority == 'f')
{
if (!SetPriorityClass(GetCurrentProcess(), REALTIME_PRIORITY_CLASS))
{
printf("SetPriorityClass failed:%d\n", GetLastError());
return FALSE;
}
printf("REALTIME_PRIORITY_CLASS\n");
}
/*if (cPriority == 's')
{
Sleep(30000);
printf("Sleeping..\n");
}*/
//ResumeThread(hPThread);
}
CloseHandle(hPThread);
return TRUE;
} BOOL main(){
HANDLE hPThread;
if (!DuplicateHandle(GetCurrentProcess(), GetCurrentThread(), GetCurrentProcess(),
&hPThread, THREAD_SUSPEND_RESUME, FALSE, DUPLICATE_SAME_ACCESS))
{
printf("Dupilicate failed:%d", GetLastError());
return FALSE;
} _beginthreadex(NULL, , ThreadFunc, NULL, , NULL); int i = ;
printf("Enter while\n");
while (TRUE){
i++;
ofstream outfile;
outfile.open("E:\\Coding\\test\\test2.txt");
outfile << "Run service success..\n" << endl;
outfile.close();
}
return TRUE;
}

当启动这个线程和它的副本的时候,二者CPU占用率差不多:

现在调低188.exe的优先级,调到IDLE优先级后,其CPU占用率立即下降:

如果改成实时的优先级,其CUP占用率就会提升:

确实会有变化,但是并不像书中说的那么明显。

《Windows核心编程》第七章——进程优先级实验的更多相关文章

  1. Windows核心编程 第七章 线程的调度、优先级和亲缘性(下)

    7.6 运用结构环境 现在应该懂得环境结构在线程调度中所起的重要作用了.环境结构使得系统能够记住线程的状态,这样,当下次线程拥有可以运行的C P U时,它就能够找到它上次中断运行的地方. 知道这样低层 ...

  2. windows核心编程---第七章 用户模式下的线程同步

    用户模式下的线程同步 系统中的线程必须访问系统资源,如堆.串口.文件.窗口以及其他资源.如果一个线程独占了对某个资源的访问,其他线程就无法完成工作.我们也必须限制线程在任何时刻都能访问任何资源.比如在 ...

  3. Windows核心编程 第七章 线程的调度、优先级和亲缘性(上)

    第7章 线程的调度.优先级和亲缘性 抢占式操作系统必须使用某种算法来确定哪些线程应该在何时调度和运行多长时间.本章将要介绍Microsoft Windows 98和Windows 2000使用的一些算 ...

  4. windows核心编程 第8章201页旋转锁的代码在新版Visual Studio运行问题

    // 全局变量,用于指示共享的资源是否在使用 BOOL g_fResourceInUse = FALSE; void Func1() { //等待访问资源 while(InterlockedExcha ...

  5. windows核心编程 第5章job lab示例程序 解决小技巧

    看到windows核心编程 第5章的最后一节,发现job lab例子程序不能在我的系统(win8下)正常运行,总是提示“进程在一个作业里”         用process explorer程序查看 ...

  6. Windows核心编程 第三章 内核对象

    第3章内核对象 在介绍Windows API的时候,首先要讲述内核对象以及它们的句柄.本章将要介绍一些比较抽象的概念,在此并不讨论某个特定内核对象的特性,相反只是介绍适用于所有内核对象的特性. 首先介 ...

  7. windows核心编程---第六章 线程的调度

    每个线程都有一个CONTEXT结构,保存在线程内核对象中.大约每隔20ms windows就会查看所有当前存在的线程内核对象.并在可调度的线程内核对象中选择一个,将其保存在CONTEXT结构的值载入c ...

  8. Windows核心编程 第27章 硬件输入模型和局部输入状态

    第27章 硬件输入模型和局部输入状态 这章说的是按键和鼠标事件是如何进入系统并发送给适当的窗口过程的.微软设计输入模型的一个主要目标就是为了保证一个线程的动作不要对其他线程的动作产生不好的影响. 27 ...

  9. Windows核心编程 第十七章 -内存映射文件(下)

    17.3 使用内存映射文件 若要使用内存映射文件,必须执行下列操作步骤: 1) 创建或打开一个文件内核对象,该对象用于标识磁盘上你想用作内存映射文件的文件. 2) 创建一个文件映射内核对象,告诉系统该 ...

随机推荐

  1. snmp常见操作

    常用snmp OID说明下面这些值可以手动连接进行获取数据: 用zabbix监控交换机和路由器需要一款能够获取网络设备OID的工具,可用getif来获得OID 也可以使用snmpwalk 配置交换机的 ...

  2. 2017 Tag Cloud

    距离上一篇随笔已经过去了三年多,惊讶地发现我还有个博客在这里 :) 越来越懒,这三年多就用下面这个tag cloud来总结好了

  3. Phoenix的安装使用与SQL查询HBase

    一. Phoenix的简介 1. 什么是phoenix 现有hbase的查询工具有很多如:Hive,Tez,Impala,Shark/Spark,Phoenix等.今天主要说Phoenix.phoen ...

  4. Tuning Optimization

    2017-02-22 在经过Trace的分析并重新优化之后 CPU: Intel(R) Xeon(R) CPU E5-2630 v2 @ 2.6GHz 24core 如上图,CPU使用率平均低于60% ...

  5. 20169211 《Linux内核原理与分析》第十一周作业

    SET-UID程序漏洞实验 一.实验简介 Set-UID 是Unix系统中的一个重要的安全机制.当一个Set-UID程序运行的时候,它被假设为具有拥有者的权限.例如,如果程序的拥有者是root,那么任 ...

  6. 20169211《Linux内核原理与分析》 第九周作业

    一.Linux内核虚拟文件系统学习总结 Linux支持各种文件系统,Linux内核通过虚拟文件系统了对各种文件系统共性的进行抽象,并对外提供统一接口,从面向对象编程的角度来看,称为抽象文件系统更为合适 ...

  7. POJ - 1329 Circle Through Three Points 求圆

    Circle Through Three Points Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 4112   Acce ...

  8. JAVAEE——Lucene基础:什么是全文检索、Lucene实现全文检索的流程、配置开发环境、索引库创建与管理

    1. 学习计划 第一天:Lucene的基础知识 1.案例分析:什么是全文检索,如何实现全文检索 2.Lucene实现全文检索的流程 a) 创建索引 b) 查询索引 3.配置开发环境 4.创建索引库 5 ...

  9. jQuery事件和动画

    1.toggle事件 <!DOCTYPE html>   <html>   <head lang="en">   <meta charse ...

  10. BZOJ2120数颜色(带修改莫队)

    莫队算法是一种数据结构的根号复杂度替代品,主要应用在询问[l,r]到询问[l+1,r]和[l,r+1]这两个插入和删除操作复杂度都较低的情况下.具体思想是:如果把一个询问[l,r]看做平面上的点(l, ...