微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

在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版本.

原文地址:https://www.jb51.cc/windows/372170.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐