在Windows上嵌入Python:为什么它必须是DLL?

我正在尝试编写一个嵌入Python的软件插件.在Windows上,插件在技术上是一个DLL(这可能是相关的). Python Windows FAQ说:

1.Do not build Python into your .exe file directly. On Windows,Python must be a DLL to handle importing modules that are themselves DLL’s. (This is the first key undocumented fact.) Instead,link to pythonNN.dll; it is typically installed in C:\Windows\System. NN is the Python version,a number such as “23” for Python 2.3.

我的问题是为什么Python必须是一个DLL?如果在我的情况下,主机应用程序不是.exe,而且是DLL,我可以在其中构建Python吗?或者,也许,这个说明意味着第三方C扩展依赖于pythonN.N.dll存在而其他DLL不会这样做?假设我真的想拥有一个DLL,我该怎么办?

我看到有dynload_win.c文件,它似乎是在Windows上导入C扩展的模块,据我所知,它扫描扩展文件以找到它导入的pythonX.X.dll;但我对Windows没有经验,我不太了解那里的所有代码.

您需要链接到pythonXY.dll作为DLL,而不是将相关代码直接链接到您的可执行文件,因为否则Python运行时无法加载其他DLL(它依赖的扩展模块.)如果你自己制作DLL理论上可以直接链接该DLL中的所有Python代码,因为它不会在可执行文件中结束,但仍然在DLL中.但是,您必须注意正确地进行链接,因为几乎所有标准工具(如distutils)都不会为您执行此操作.

但是,无论你如何嵌入Python,你都不能只使用DLL,也不能只使用任何DLL. ABI在Python版本之间发生了变化,因此如果您针对Python 2.6编译代码,则需要python26.dll;你不能使用python25.dll或python27.dll. Python不仅仅是一个DLL;它还需要它的标准库,其中包括扩展模块(虽然它们具有.pyd扩展名,但它们本身就是DLL.)您遇到的dynload_win.c中的代码用于加载这些DLL,与加载pythonXY无关. DLL.

简而言之,为了在您的插件中嵌入Python,您需要使用插件发布Python,或者要求已经安装了正确的Python版本.

相关文章

Windows2012R2备用域控搭建 前置操作 域控主域控的主dns:自...
主域控角色迁移和夺取(转载) 转载自:http://yupeizhi.blo...
Windows2012R2 NTP时间同步 Windows2012R2里没有了internet时...
Windows注册表操作基础代码 Windows下对注册表进行操作使用的...
黑客常用WinAPI函数整理之前的博客写了很多关于Windows编程的...
一个简单的Windows Socket可复用框架说起网络编程,无非是建...