进程与线程(一):一些关于进程的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

相关文章

Linux线程同步/互斥过程详解

《Linux线程同步/互斥过程详解》文章讲解多线程并发访问导致竞态条件,需通过互斥锁、原子操作和条件变量实现线程安全与同步,分析死锁条件及避免方法,并介绍RAII封装技术提升资源管理效率... 目录01. 资源共享问题1.1 多线程并发访问1.2 临界区与临界资源1.3 锁的引入02. 多线程案例2.1 为

python panda库从基础到高级操作分析

《pythonpanda库从基础到高级操作分析》本文介绍了Pandas库的核心功能,包括处理结构化数据的Series和DataFrame数据结构,数据读取、清洗、分组聚合、合并、时间序列分析及大数据... 目录1. Pandas 概述2. 基本操作:数据读取与查看3. 索引操作:精准定位数据4. Group

Python操作PDF文档的主流库使用指南

《Python操作PDF文档的主流库使用指南》PDF因其跨平台、格式固定的特性成为文档交换的标准,然而,由于其复杂的内部结构,程序化操作PDF一直是个挑战,本文主要为大家整理了Python操作PD... 目录一、 基础操作1.PyPDF2 (及其继任者 pypdf)2.PyMuPDF / fitz3.Fre

SpringBoot监控API请求耗时的6中解决解决方案

《SpringBoot监控API请求耗时的6中解决解决方案》本文介绍SpringBoot中记录API请求耗时的6种方案,包括手动埋点、AOP切面、拦截器、Filter、事件监听、Micrometer+... 目录1. 简介2.实战案例2.1 手动记录2.2 自定义AOP记录2.3 拦截器技术2.4 使用Fi

Python对接支付宝支付之使用AliPay实现的详细操作指南

《Python对接支付宝支付之使用AliPay实现的详细操作指南》支付宝没有提供PythonSDK,但是强大的github就有提供python-alipay-sdk,封装里很多复杂操作,使用这个我们就... 目录一、引言二、准备工作2.1 支付宝开放平台入驻与应用创建2.2 密钥生成与配置2.3 安装ali

MySQL 强制使用特定索引的操作

《MySQL强制使用特定索引的操作》MySQL可通过FORCEINDEX、USEINDEX等语法强制查询使用特定索引,但优化器可能不采纳,需结合EXPLAIN分析执行计划,避免性能下降,注意版本差异... 目录1. 使用FORCE INDEX语法2. 使用USE INDEX语法3. 使用IGNORE IND

Java中的xxl-job调度器线程池工作机制

《Java中的xxl-job调度器线程池工作机制》xxl-job通过快慢线程池分离短时与长时任务,动态降级超时任务至慢池,结合异步触发和资源隔离机制,提升高频调度的性能与稳定性,支撑高并发场景下的可靠... 目录⚙️ 一、调度器线程池的核心设计 二、线程池的工作流程 三、线程池配置参数与优化 四、总结:线程

Python使用openpyxl读取Excel的操作详解

《Python使用openpyxl读取Excel的操作详解》本文介绍了使用Python的openpyxl库进行Excel文件的创建、读写、数据操作、工作簿与工作表管理,包括创建工作簿、加载工作簿、操作... 目录1 概述1.1 图示1.2 安装第三方库2 工作簿 workbook2.1 创建:Workboo

WinForm跨线程访问UI及UI卡死的解决方案

《WinForm跨线程访问UI及UI卡死的解决方案》在WinForm开发过程中,跨线程访问UI控件和界面卡死是常见的技术难题,由于Windows窗体应用程序的UI控件默认只能在主线程(UI线程)上操作... 目录前言正文案例1:直接线程操作(无UI访问)案例2:BeginInvoke访问UI(错误用法)案例

一文解密Python进行监控进程的黑科技

《一文解密Python进行监控进程的黑科技》在计算机系统管理和应用性能优化中,监控进程的CPU、内存和IO使用率是非常重要的任务,下面我们就来讲讲如何Python写一个简单使用的监控进程的工具吧... 目录准备工作监控CPU使用率监控内存使用率监控IO使用率小工具代码整合在计算机系统管理和应用性能优化中,监