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

相关文章

Windows命令之tasklist命令用法详解(Windows查看进程)

《Windows命令之tasklist命令用法详解(Windows查看进程)》tasklist命令显示本地计算机或远程计算机上当前正在运行的进程列表,命令结合筛选器一起使用,可以按照我们的需求进行过滤... 目录命令帮助1、基本使用2、执行原理2.1、tasklist命令无法使用3、筛选器3.1、根据PID

Java捕获ThreadPoolExecutor内部线程异常的四种方法

《Java捕获ThreadPoolExecutor内部线程异常的四种方法》这篇文章主要为大家详细介绍了Java捕获ThreadPoolExecutor内部线程异常的四种方法,文中的示例代码讲解详细,感... 目录方案 1方案 2方案 3方案 4结论方案 1使用 execute + try-catch 记录

SpringBoot操作MaxComputer方式(保姆级教程)

《SpringBoot操作MaxComputer方式(保姆级教程)》:本文主要介绍SpringBoot操作MaxComputer方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的... 目录引言uqNqjoe一、引入依赖二、配置文件 application.properties(信息用自己

C#中的 Dictionary常用操作

《C#中的Dictionary常用操作》C#中的DictionaryTKey,TValue是用于存储键值对集合的泛型类,允许通过键快速检索值,并且具有唯一键、动态大小和无序集合的特性,常用操作包括添... 目录基本概念Dictionary的基本结构Dictionary的主要特性Dictionary的常用操作

C# winform操作CSV格式文件

《C#winform操作CSV格式文件》这篇文章主要为大家详细介绍了C#在winform中的表格操作CSV格式文件的相关实例,文中的示例代码讲解详细,感兴趣的小伙伴可以参考一下... 目录实例一实例效果实现代码效果展示实例二实例效果完整代码实例一实例效果当在winform界面中点击读取按钮时 将csv中

linux本机进程间通信之UDS详解

《linux本机进程间通信之UDS详解》文章介绍了Unix域套接字(UDS)的使用方法,这是一种在同一台主机上不同进程间通信的方式,UDS支持三种套接字类型:SOCK_STREAM、SOCK_DGRA... 目录基础概念本机进程间通信socket实现AF_INET数据收发示意图AF_Unix数据收发流程图A

C#集成DeepSeek模型实现AI私有化的流程步骤(本地部署与API调用教程)

《C#集成DeepSeek模型实现AI私有化的流程步骤(本地部署与API调用教程)》本文主要介绍了C#集成DeepSeek模型实现AI私有化的方法,包括搭建基础环境,如安装Ollama和下载DeepS... 目录前言搭建基础环境1、安装 Ollama2、下载 DeepSeek R1 模型客户端 ChatBo

Spring Boot 中正确地在异步线程中使用 HttpServletRequest的方法

《SpringBoot中正确地在异步线程中使用HttpServletRequest的方法》文章讨论了在SpringBoot中如何在异步线程中正确使用HttpServletRequest的问题,... 目录前言一、问题的来源:为什么异步线程中无法访问 HttpServletRequest?1. 请求上下文与线

在 Spring Boot 中使用异步线程时的 HttpServletRequest 复用问题记录

《在SpringBoot中使用异步线程时的HttpServletRequest复用问题记录》文章讨论了在SpringBoot中使用异步线程时,由于HttpServletRequest复用导致... 目录一、问题描述:异步线程操作导致请求复用时 Cookie 解析失败1. 场景背景2. 问题根源二、问题详细分

Python中多线程和多进程的基本用法详解

《Python中多线程和多进程的基本用法详解》这篇文章介绍了Python中多线程和多进程的相关知识,包括并发编程的优势,多线程和多进程的概念、适用场景、示例代码,线程池和进程池的使用,以及如何选择合适... 目录引言一、并发编程的主要优势二、python的多线程(Threading)1. 什么是多线程?2.