进程与线程(一):一些关于进程的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线程之线程的创建、属性、回收、退出、取消方式》文章总结了线程管理核心知识:线程号唯一、创建方式、属性设置(如分离状态与栈大小)、回收机制(join/detach)、退出方法(返回/pthr... 目录1. 线程号2. 线程的创建3. 线程属性4. 线程的回收5. 线程的退出6. 线程的取消7.

Linux下进程的CPU配置与线程绑定过程

《Linux下进程的CPU配置与线程绑定过程》本文介绍Linux系统中基于进程和线程的CPU配置方法,通过taskset命令和pthread库调整亲和力,将进程/线程绑定到特定CPU核心以优化资源分配... 目录1 基于进程的CPU配置1.1 对CPU亲和力的配置1.2 绑定进程到指定CPU核上运行2 基于

Javaee多线程之进程和线程之间的区别和联系(最新整理)

《Javaee多线程之进程和线程之间的区别和联系(最新整理)》进程是资源分配单位,线程是调度执行单位,共享资源更高效,创建线程五种方式:继承Thread、Runnable接口、匿名类、lambda,r... 目录进程和线程进程线程进程和线程的区别创建线程的五种写法继承Thread,重写run实现Runnab

SpringBoot线程池配置使用示例详解

《SpringBoot线程池配置使用示例详解》SpringBoot集成@Async注解,支持线程池参数配置(核心数、队列容量、拒绝策略等)及生命周期管理,结合监控与任务装饰器,提升异步处理效率与系统... 目录一、核心特性二、添加依赖三、参数详解四、配置线程池五、应用实践代码说明拒绝策略(Rejected

Java操作Word文档的全面指南

《Java操作Word文档的全面指南》在Java开发中,操作Word文档是常见的业务需求,广泛应用于合同生成、报表输出、通知发布、法律文书生成、病历模板填写等场景,本文将全面介绍Java操作Word文... 目录简介段落页头与页脚页码表格图片批注文本框目录图表简介Word编程最重要的类是org.apach

Knife4j+Axios+Redis前后端分离架构下的 API 管理与会话方案(最新推荐)

《Knife4j+Axios+Redis前后端分离架构下的API管理与会话方案(最新推荐)》本文主要介绍了Swagger与Knife4j的配置要点、前后端对接方法以及分布式Session实现原理,... 目录一、Swagger 与 Knife4j 的深度理解及配置要点Knife4j 配置关键要点1.Spri

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.

Java进程异常故障定位及排查过程

《Java进程异常故障定位及排查过程》:本文主要介绍Java进程异常故障定位及排查过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、故障发现与初步判断1. 监控系统告警2. 日志初步分析二、核心排查工具与步骤1. 进程状态检查2. CPU 飙升问题3. 内存

Python实现对阿里云OSS对象存储的操作详解

《Python实现对阿里云OSS对象存储的操作详解》这篇文章主要为大家详细介绍了Python实现对阿里云OSS对象存储的操作相关知识,包括连接,上传,下载,列举等功能,感兴趣的小伙伴可以了解下... 目录一、直接使用代码二、详细使用1. 环境准备2. 初始化配置3. bucket配置创建4. 文件上传到os

Java 线程安全与 volatile与单例模式问题及解决方案

《Java线程安全与volatile与单例模式问题及解决方案》文章主要讲解线程安全问题的五个成因(调度随机、变量修改、非原子操作、内存可见性、指令重排序)及解决方案,强调使用volatile关键字... 目录什么是线程安全线程安全问题的产生与解决方案线程的调度是随机的多个线程对同一个变量进行修改线程的修改操