进程与线程(一):一些关于进程的r3级API操作(1)

2023-12-03 00:38
文章标签 线程 操作 进程 api r3

本文主要是介绍进程与线程(一):一些关于进程的r3级API操作(1),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

   最近研究进程与线程,用reactos走了2遍内核executive层面的进程管理代码,看着真晕,为了缓解下大脑,看一点ring3的东西,《windows via c/c++》第四章,记下笔记。

很无聊的代码,就是试试几个API,无技术含量,无返回值判断,无实际功能的三无代码。

如果有人无聊要编译的话,不通过是很正常的,include 和 lib 还有一个函数没贴出来 

    1 int _tmain(int argc, TCHAR* argv[], TCHAR* envp[]) 2 { 3     _tsetlocale(LC_ALL,_T("chs") );  4     ::system("title ReturnsMe的win32api测试程序"); 5 6     //2009年8月19日 windows via c/c++ 第四章 读书笔记 7 8 9     //1.关于实例句柄 10     HMODULE hmodule =GetModuleHandle(_T("NTDLL.DLL")); 11          12     TCHAR szFilePath[MAX_PATH+1]; 13 14     //winmain中的hInstance 是应用程序独一无二的实例句柄,我们通过这个实例句柄得到文件的完整路径.由于我们这个是控制台程序 15     //所以先用GetModuleHandle(NULL)得到这个hInstance,hInstance与hmodule是一回事儿。 16     //如果我们这里传入一个文件名,比如NTDLL.DLL,就可以得到这个文件的相关信息 17 18     GetModuleFileName(hmodule,szFilePath,sizeof(szFilePath)/sizeof(szFilePath[0])); 19 20     wprintf(_T("path:  %s \n"),szFilePath); 21     wprintf(_T("ImageBase:  0x%x \n"),hmodule); 22      23     //2.得到命令行参数 24     //GetCommandLine()获取命令行参数,然后可以调用CommandLineToArgvW()转换,这里先不做相信描述,用到再说吧。 25      26 27     //3.得到进程所在驱动器和目录 28     TCHAR szBuff[MAX_PATH+1]; 29     GetCurrentDirectory(MAX_PATH+1,szBuff); 30     wprintf(_T("mydir:  %s \n"),szBuff); 31 32     //4.GetFullPathName 与3处理方法类似 33 34     //5,得到系统版本,搞不懂为什么osinfo要强制转换成LPOSVERSIONINFO才能编译通过, 35     //可能是声明的问题。。。是否是EX,要api根据sizeof的大小判断 36 37     OSVERSIONINFOEX osinfo; 38     osinfo.dwOSVersionInfoSize = sizeof(OSVERSIONINFOEX); 39     GetVersionEx((LPOSVERSIONINFO)&osinfo); 40     wprintf(_T("osinfo:  %d.%d sp%d.%d \n"),osinfo.dwMajorVersion,osinfo.dwMinorVersion,osinfo.wServicePackMajor,osinfo.wServicePackMinor); 41      42     //6 CreateProcess 创建进程,ExitProcess结束自身进程,TerminateProcess 结束其他进程 43     STARTUPINFO si = {sizeof(si)}; 44     PROCESS_INFORMATION pi; 45     TCHAR szExeName[ ]= _T("E:\\Work\\Code\\Mydriver\\WIN32API\\Debug\\rm.exe"); 46      47     //WaitForSingleObject的作用是等待子进程处理结束才继续 48     CreateProcess(szExeName,NULL,NULL,NULL,FALSE,NULL,NULL,NULL,&si,&pi); 49     WaitForSingleObject(pi.hProcess,INFINITE); 50 51     //7.PEB的操作有很多,文章也不少了,这里弄一个无聊的。获取某个进程的peb地址,在vista中,peb是动态的,不能通过硬编码获得。 52 53     CString  strAppName; 54     DWORD dwAppPID; 55     wchar_t wcTemp[260]; 56 57     wprintf(_T("请输入程序名:\n")); 58     wscanf(L"%s",wcTemp); 59     strAppName.Format(L"%s",wcTemp); 60 61     dwAppPID = GetProcessIdFromName(strAppName); 62 63     if (-2 == dwAppPID) 64     { 65         wprintf(_T("无此进程\n")); 66     } 67 68     HANDLE hProc = OpenProcess(PROCESS_ALL_ACCESS,FALSE,dwAppPID); 69 70     PROCESS_BASIC_INFORMATION  proinfo; 71     ZwQueryInformationProcess(hProc,ProcessBasicInformation,(PVOID)&proinfo,sizeof(proinfo),NULL); 72     PPEB PEBaddr = proinfo.PebBaseAddress; 73     wprintf(_T("PEB:  0x%x \n"),PEBaddr); 74 75      76 77      78 79     ::system("pause"); 80 81     return 0; 82 }


这篇关于进程与线程(一):一些关于进程的r3级API操作(1)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/447455

相关文章

Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单

《Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单》:本文主要介绍Springboot的ThreadPoolTaskScheduler线... 目录ThreadPoolTaskScheduler线程池实现15分钟不操作自动取消订单概要1,创建订单后

SpringBoot操作spark处理hdfs文件的操作方法

《SpringBoot操作spark处理hdfs文件的操作方法》本文介绍了如何使用SpringBoot操作Spark处理HDFS文件,包括导入依赖、配置Spark信息、编写Controller和Ser... 目录SpringBoot操作spark处理hdfs文件1、导入依赖2、配置spark信息3、cont

使用JavaScript操作本地存储

《使用JavaScript操作本地存储》这篇文章主要为大家详细介绍了JavaScript中操作本地存储的相关知识,文中的示例代码讲解详细,具有一定的借鉴价值,有需要的小伙伴可以参考一下... 目录本地存储:localStorage 和 sessionStorage基本使用方法1. localStorage

使用JavaScript将PDF页面中的标注扁平化的操作指南

《使用JavaScript将PDF页面中的标注扁平化的操作指南》扁平化(flatten)操作可以将标注作为矢量图形包含在PDF页面的内容中,使其不可编辑,DynamsoftDocumentViewer... 目录使用Dynamsoft Document Viewer打开一个PDF文件并启用标注添加功能扁平化

JavaScript DOM操作与事件处理方法

《JavaScriptDOM操作与事件处理方法》本文通过一系列代码片段,详细介绍了如何使用JavaScript进行DOM操作、事件处理、属性操作、内容操作、尺寸和位置获取,以及实现简单的动画效果,涵... 目录前言1. 类名操作代码片段代码解析2. 属性操作代码片段代码解析3. 内容操作代码片段代码解析4.

C语言线程池的常见实现方式详解

《C语言线程池的常见实现方式详解》本文介绍了如何使用C语言实现一个基本的线程池,线程池的实现包括工作线程、任务队列、任务调度、线程池的初始化、任务添加、销毁等步骤,感兴趣的朋友跟随小编一起看看吧... 目录1. 线程池的基本结构2. 线程池的实现步骤3. 线程池的核心数据结构4. 线程池的详细实现4.1 初

SpringBoot使用Apache POI库读取Excel文件的操作详解

《SpringBoot使用ApachePOI库读取Excel文件的操作详解》在日常开发中,我们经常需要处理Excel文件中的数据,无论是从数据库导入数据、处理数据报表,还是批量生成数据,都可能会遇到... 目录项目背景依赖导入读取Excel模板的实现代码实现代码解析ExcelDemoInfoDTO 数据传输

Python使用asyncio实现异步操作的示例

《Python使用asyncio实现异步操作的示例》本文主要介绍了Python使用asyncio实现异步操作的示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋... 目录1. 基础概念2. 实现异步 I/O 的步骤2.1 定义异步函数2.2 使用 await 等待异

Java子线程无法获取Attributes的解决方法(最新推荐)

《Java子线程无法获取Attributes的解决方法(最新推荐)》在Java多线程编程中,子线程无法直接获取主线程设置的Attributes是一个常见问题,本文探讨了这一问题的原因,并提供了两种解决... 目录一、问题原因二、解决方案1. 直接传递数据2. 使用ThreadLocal(适用于线程独立数据)

C#如何优雅地取消进程的执行之Cancellation详解

《C#如何优雅地取消进程的执行之Cancellation详解》本文介绍了.NET框架中的取消协作模型,包括CancellationToken的使用、取消请求的发送和接收、以及如何处理取消事件... 目录概述与取消线程相关的类型代码举例操作取消vs对象取消监听并响应取消请求轮询监听通过回调注册进行监听使用Wa