翻译《The Old New Thing》- What did MakeProcInstance do?

2024-05-29 02:52

本文主要是介绍翻译《The Old New Thing》- What did MakeProcInstance do?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

What did MakeProcInstance do? - The Old New Thing (microsoft.com)icon-default.png?t=N7T8https://devblogs.microsoft.com/oldnewthing/20080207-00/?p=23533

Raymond Chen 2008年02月07日


 MakeProcInstance 做了什么?

      MakeProcInstance 宏实际上什么也不做。

#define MakeProcInstance(lpProc,hInstance) (lpProc)

        一个什么也不做的宏有什么意义呢?

        在16位Windows系统中,MakeProcInstance 是有作用的。

        回想一下,在16位Windows系统中,HINSTANCE 是用来标识数据段的机制;也就是说,是代表模块使用中的变量集合的一块内存。如果你运行了两个记事本的副本,代码只有一个副本,但变量有两套(每份副本一套)。正是这第二套变量建立了记事本的第二个副本。

        当你设置一个回调函数,比如窗口过程时,回调函数需要知道它被调用是为了哪一套变量。例如,如果一个记事本副本调用 EnumFonts 并传递一个回调函数,这个函数需要知道它正在哪个记事本副本中运行,以便它可以访问正确的变量集合。这就是 MakeProcInstance 函数的作用。

  MakeProcInstance 的参数是一个函数指针和一个实例句柄。MakeProcInstance 函数会即时生成代码,将数据段寄存器设置为实例句柄,然后跳转到原始函数指针。MakeProcInstance 的返回值是指向那个动态生成的代码片段(称为 thunk)的指针,并且你在使用该代码片段作为函数指针时,需要其他函数回调你。这样,当你的函数被调用时,它的变量就会正确设置。

        当你不再需要代码片段时,你可以使用 FreeProcInstance 函数释放它。

        那些使用过ATL的人已经在 CStdCallThunk 类中看到过这种代码片段生成。操作与 MakeProcInstance 完全类似。你使用函数指针和 this 参数初始化 CStdCallThunk,它即时生成代码,通过在调用你初始化thunk时使用的函数之前设置 this 指针,将静态函数转换为 C++ 成员函数。

        在16位Windows上创建这些代码片段必须由内核完成,因为8086处理器没有内存管理单元。没有通过转换表的间接寻址;所有地址都是物理的。因此,如果内存管理器需要移动内存,它还必须知道所有移动内存的引用位置,以便可以更新指针。如果数据段移动了,内核必须去修复所有的 MakeProcInstance thunks,以便它们使用新的实例句柄而不是旧的。

        是 Michael Geary 发现所有这些 MakeProcInstance 工作是不必要的。如果回调函数位于DLL中,那么函数可以硬编码其实例句柄,并在函数开始时加载它;这种技术最终被称为 loadds。由于DLL是单实例的,DLL已经知道它应该使用哪一套变量,因为从一开始就只有一套DLL变量!

当然,硬编码的值必须作为修正记录,因为实例句柄是在运行时确定的。另外,内核需要知道如果实例句柄的值改变,需要更新哪些值。

        另一方面,如果回调函数位于可执行文件中,那么它可以从堆栈选择器中获取其实例句柄;这种技术最终被称为 export。每个程序在一个堆栈上运行(这里没有多线程),堆栈、数据段和本地堆都按照惯例位于同一个选择器中。

        在我写这篇回忆录时,我发现了一个奇怪的回环,Michael Geary 的 FixDS 程序的原始自述文件中,有一段介绍与我有关,链接回我本人…

这篇关于翻译《The Old New Thing》- What did MakeProcInstance do?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

论文翻译:arxiv-2024 Benchmark Data Contamination of Large Language Models: A Survey

Benchmark Data Contamination of Large Language Models: A Survey https://arxiv.org/abs/2406.04244 大规模语言模型的基准数据污染:一项综述 文章目录 大规模语言模型的基准数据污染:一项综述摘要1 引言 摘要 大规模语言模型(LLMs),如GPT-4、Claude-3和Gemini的快

论文翻译:ICLR-2024 PROVING TEST SET CONTAMINATION IN BLACK BOX LANGUAGE MODELS

PROVING TEST SET CONTAMINATION IN BLACK BOX LANGUAGE MODELS https://openreview.net/forum?id=KS8mIvetg2 验证测试集污染在黑盒语言模型中 文章目录 验证测试集污染在黑盒语言模型中摘要1 引言 摘要 大型语言模型是在大量互联网数据上训练的,这引发了人们的担忧和猜测,即它们可能已

java线程深度解析(一)——java new 接口?匿名内部类给你答案

http://blog.csdn.net/daybreak1209/article/details/51305477 一、内部类 1、内部类初识 一般,一个类里主要包含类的方法和属性,但在Java中还提出在类中继续定义类(内部类)的概念。 内部类的定义:类的内部定义类 先来看一个实例 [html]  view plain copy pu

string字符会调用new分配堆内存吗

gcc的string默认大小是32个字节,字符串小于等于15直接保存在栈上,超过之后才会使用new分配。

excel翻译软件有哪些?如何高效提翻译?

你是否曾在面对满屏的英文Excel表格时感到头疼?项目报告、数据分析、财务报表... 当这些重要的信息被语言壁垒阻挡时,效率和理解度都会大打折扣。别担心,只需3分钟,我将带你轻松解锁excel翻译成中文的秘籍。 无论是职场新人还是老手,这一技巧都将是你的得力助手,让你在信息的海洋中畅游无阻。 方法一:使用同声传译王软件 同声传译王是一款专业的翻译软件,它支持多种语言翻译,可以excel

MonoHuman: Animatable Human Neural Field from Monocular Video 翻译

MonoHuman:来自单目视频的可动画人类神经场 摘要。利用自由视图控制来动画化虚拟化身对于诸如虚拟现实和数字娱乐之类的各种应用来说是至关重要的。已有的研究试图利用神经辐射场(NeRF)的表征能力从单目视频中重建人体。最近的工作提出将变形网络移植到NeRF中,以进一步模拟人类神经场的动力学,从而动画化逼真的人类运动。然而,这种流水线要么依赖于姿态相关的表示,要么由于帧无关的优化而缺乏运动一致性

linux dlopen手册翻译

名称 dlclose, dlopen, dlmopen 打开和关闭一个共享对象 简介 #include <dlfcn.h>void *dlopen(const char*filename, int flags);int dlclose(void *handle);#define _GNU_SOURCE#include <dlfcn.h>void *dlmoopen(Lmid_t lm

从计组中从重温C中浮点数表示及C程序翻译过程

目录 移码​编辑  传统浮点表示格式 浮点数的存储(ieee 754)->修炼内功 例子:   ​编辑 浮点数取的过程   C程序翻译过程 移码  传统浮点表示格式 浮点数的存储(ieee 754)->修炼内功 根据国际标准IEEE(电⽓和电⼦⼯程协会)  32位 例子:    64位    IEEE754对有效数字M和

List list = new ArrayList();和ArrayList list=new ArrayList();的区别?

List是一个接口,而ArrayList 是一个类。 ArrayList 继承并实现了List。 List list = new ArrayList();这句创建了一个ArrayList的对象后把上溯到了List。此时它是一个List对象了,有些ArrayList有但是List没有的属性和方法,它就不能再用了。而ArrayList list=new ArrayList();创建一对象则保留了A

HumanNeRF:Free-viewpoint Rendering of Moving People from Monocular Video 翻译

HumanNeRF:单目视频中运动人物的自由视点绘制 引言。我们介绍了一种自由视点渲染方法- HumanNeRF -它适用于一个给定的单眼视频ofa人类执行复杂的身体运动,例如,从YouTube的视频。我们的方法可以在任何帧暂停视频,并从任意新的摄像机视点或甚至针对该特定帧和身体姿势的完整360度摄像机路径渲染主体。这项任务特别具有挑战性,因为它需要合成身体的照片级真实感细节,如从输入视频中可能