#include <windows.h>
#include<iostream>
#include <tchar.h>
using namespace std; typedef struct ThreadParam{
HANDLE hIOCP;
DWORD dwNumBytesTransferred;
ULONG CompletionKey;
LPOVERLAPPED pOverlapped;
DWORD dwTimeOut;
}*pThreadParam; void MonitorCompletePort(LPVOID lpParam){
pThreadParam tp = (pThreadParam)lpParam;
BOOL bRuslt = FALSE;
printf("Run thread success.\n");
while (TRUE){
bRuslt = GetQueuedCompletionStatus(tp->hIOCP, &tp->dwNumBytesTransferred, &tp->CompletionKey, &tp->pOverlapped, INFINITE);
switch (tp->dwNumBytesTransferred){
case JOB_OBJECT_MSG_END_OF_JOB_TIME:
printf("JOB_OBJECT_MSG_END_OF_JOB_TIME\n");
break;
case JOB_OBJECT_MSG_END_OF_PROCESS_TIME:
printf("JOB_OBJECT_MSG_END_OF_PROCESS_TIME\n");
break;
case JOB_OBJECT_MSG_ACTIVE_PROCESS_LIMIT:
printf("JOB_OBJECT_MSG_ACTIVE_PROCESS_LIMIT\n");
break;
case JOB_OBJECT_MSG_ACTIVE_PROCESS_ZERO:
printf("JOB_OBJECT_MSG_ACTIVE_PROCESS_ZERO\n");
break;
case JOB_OBJECT_MSG_NEW_PROCESS:
printf("JOB_OBJECT_MSG_NEW_PROCESS\n");
break;
case JOB_OBJECT_MSG_EXIT_PROCESS:
printf("JOB_OBJECT_MSG_EXIT_PROCESS\n");
break;
case JOB_OBJECT_MSG_ABNORMAL_EXIT_PROCESS:
printf("JOB_OBJECT_MSG_ABNORMAL_EXIT_PROCESS\n");
break;
case JOB_OBJECT_MSG_PROCESS_MEMORY_LIMIT:
printf("JOB_OBJECT_MSG_PROCESS_MEMORY_LIMIT\n");
break;
case JOB_OBJECT_MSG_JOB_MEMORY_LIMIT:
printf("JOB_OBJECT_MSG_JOB_MEMORY_LIMIT\n");
break;
case JOB_OBJECT_MSG_NOTIFICATION_LIMIT:
printf("JOB_OBJECT_MSG_NOTIFICATION_LIMIT\n");
break;
}
}
printf("End thread success.\n");
} void main(){
//Check if the process has been in a job. If not, create a job object.
BOOL bInJob = FALSE;
IsProcessInJob(GetCurrentProcess(), NULL, &bInJob);//如果用命令行启动,就返回false;如果直接用vs调试启动,就返回true。
   if (bInJob){ printf("Been in a job.\n"); }
  HANDLE hJob = CreateJobObject(NULL, _T("Wintellect_RestrictedProcessJob")); //Add some basic restrictions.
   JOBOBJECT_BASIC_LIMIT_INFORMATION jobli = { };
   jobli.PriorityClass = IDLE_PRIORITY_CLASS;
   jobli.PerJobUserTimeLimit.QuadPart = ;
   jobli.LimitFlags = JOB_OBJECT_LIMIT_PRIORITY_CLASS | JOB_OBJECT_LIMIT_JOB_TIME;
   SetInformationJobObject(hJob, JobObjectBasicLimitInformation, &jobli, sizeof(jobli));
   JOBOBJECT_BASIC_UI_RESTRICTIONS jobuir;
   jobuir.UIRestrictionsClass = JOB_OBJECT_UILIMIT_NONE;
   jobuir.UIRestrictionsClass |= JOB_OBJECT_UILIMIT_EXITWINDOWS;
   jobuir.UIRestrictionsClass |= JOB_OBJECT_UILIMIT_HANDLES;
  SetInformationJobObject(hJob, JobObjectBasicUIRestrictions, &jobuir, sizeof(jobuir)); //Create a process object
STARTUPINFO si = { sizeof(si) }; PROCESS_INFORMATION pi;
BOOL bResult = CreateProcess("C:\\Windows\\System32\\notepad.exe", NULL, NULL, NULL, FALSE, CREATE_SUSPENDED | CREATE_NEW_CONSOLE, NULL, NULL, &si, &pi);
AssignProcessToJobObject(hJob, pi.hProcess); //Create io completion port.
HANDLE hIOCP = CreateIoCompletionPort(INVALID_HANDLE_VALUE, NULL, , );
JOBOBJECT_ASSOCIATE_COMPLETION_PORT joacp; joacp.CompletionKey = (PVOID);
joacp.CompletionPort = hIOCP;
SetInformationJobObject(hJob, JobObjectAssociateCompletionPortInformation, &joacp, sizeof(joacp)); //Create a thread to monitor the job.
DWORD dwNumBytesTransferred = ;
ULONG lCompletionKey = ;
ThreadParam tp;
OVERLAPPED op = { };
tp.hIOCP = hIOCP;
tp.dwNumBytesTransferred = dwNumBytesTransferred;
tp.CompletionKey = lCompletionKey;
tp.pOverlapped = NULL;
tp.dwTimeOut = INFINITE;
DWORD lpThread;
HANDLE hThread = CreateThread(NULL, , (LPTHREAD_START_ROUTINE)MonitorCompletePort, &tp, , &lpThread); Sleep();
ResumeThread(pi.hThread); CloseHandle(pi.hThread);
WaitForSingleObject(hThread, INFINITE);//Naution:if use while(true) in the thread, the thread will never return. If use INIFINITE as param //of function WaitForSingleObject, the main thread will never return. CloseHandle(hThread); getchar(); }

第一次执行GetQueuedCompletionStatus返回6(JOB_OBJECT_MSG_NEW_PROCESS),表示将一个进程添加进一个作业;第二次执行GetQueuedCompletionStatus返回1(JOB_OBJECT_MSG_END_OF_JOB_TIME),表示作业超时;第二次执行GetQueuedCompletionStatus返回1(JOB_OBJECT_MSG_ACTIVE_PROCESS_ZERO),表示作业中进程的数量降至0.

《Windows核心编程》第五章——作业的更多相关文章

  1. Windows核心编程 第五章 作业(上)

    第5章 作 业 通常,必须将一组进程当作单个实体来处理.例如,当让 Microsoft Developer Studio为你创建一个应用程序项目时,它会生成 C l . e x e,C l . e x ...

  2. Windows核心编程 第五章 作业(下)

    5.4 查询作业统计信息 前面已经介绍了如何使用 Q u e r y I n f o r m a t i o n J o b O b j e c t函数来获取对作业的当前限制信息.也可以使用它来获取关 ...

  3. windows核心编程---第五章 线程的基础

    与前面介绍的进程一样,线程也有两部分组成.一个是线程内核对象.它是一个数据结构,操作系统用它来管理线程以及用它来存储线程的一些统计信息.另一个是线程栈,用于维护线程执行时所需的所有函数参数和局部变量. ...

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

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

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

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

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

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

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

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

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

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

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

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

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

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

随机推荐

  1. centos7上使用locate命令

    https://blog.csdn.net/yqh19880321/article/details/72426879

  2. Asp.net Vnext 中间件实现基本验证

    概述 本文已经同步到<Asp.net Vnext 系列教程 >中] vnext 没有 web.config 可以配置基本验证,本文使用中间件实现基本验证 实现 通过Startup(启动类) ...

  3. 【LOJ】#2275. 「JXOI2017」颜色

    题解 我们枚举右端点判断合法的左端点有哪些 首先,记录一下右端点右边的点的pre,也就是这个数字前一个出现的位置,取所有小于枚举右端点r的值中最大的一个做为l,用优先队列维护即可,[l + 1,r]就 ...

  4. Python实现代码行数统计工具

    我们经常想要统计项目的代码行数,但是如果想统计功能比较完善可能就不是那么简单了, 今天我们来看一下如何用python来实现一个代码行统计工具. 思路:首先获取所有文件,然后统计每个文件中代码的行数,最 ...

  5. 查看锁信息(开启InnoDB监控)

    当前mysql版本:5.6.21 一.背景 在mysql处理死锁问题时,由于show engine innodb status输出来的死锁日志无任务事务上下文,并不能很好地诊断相关事务所持有的所有锁信 ...

  6. 打开tcp_tw_recycle引起的一次投诉分析

    背景: 我们有个基于oauth2.0协议给第三方授权以及信息的业务,年前对接入层.业务层做了次迁移.业务架构简单介绍下: lvs接入---> nginx ---> tomcat   问题: ...

  7. flask使用flask_sqlalchemy连接数据库(python2.7)

    1.出现编码问题 解决方法: #连接数据库时出现编码问题,需要pip install mysql-connector-python,并且数据库配置修改为 import mysql.connector ...

  8. pip作用

    介绍 pip 是一个安装和管理 Python 包的工具,python安装包的工具有easy_install, setuptools, pip,distribute.使用这些工具都能下载并安装djang ...

  9. BZOJ.3105.[CQOI2013]新Nim游戏(线性基 贪心 博弈论)

    题目链接 如果后手想要胜利,那么在后手第一次取完石子后 可以使石子数异或和为0.那所有数异或和为0的线性基长啥样呢,不知道.. 往前想,后手可以取走某些石子使得剩下石子异或和为0,那不就是存在异或和为 ...

  10. 【堆优化Dijkstra】BZOJ4152- [AMPPZ2014]The Captain

    [题目大意] 给定平面上的n个点,定义(x1,y1)到(x2,y2)的费用为min(|x1-x2|,|y1-y2|),求从1号点走到n号点的最小费用. [思路] 按照某维坐标排序,相邻两个点在这一维度 ...