首页
/ setuptools 在 Windows 平台构建自由线程扩展时的 Py_GIL_DISABLED 宏问题解析

setuptools 在 Windows 平台构建自由线程扩展时的 Py_GIL_DISABLED 宏问题解析

2025-06-29 04:02:09作者:沈韬淼Beryl

在 Python 3.13 的自由线程(free-threaded)版本中,当开发者使用 setuptools 在 Windows 平台构建 C 扩展模块时,可能会遇到一个关键问题:Py_GIL_DISABLED 宏未被正确定义,导致构建的扩展模块在导入时崩溃。

问题背景

Python 3.13 引入了自由线程构建选项,这种构建方式移除了全局解释器锁(GIL)。在 Windows 平台上,自由线程版本使用不同的动态链接库(python313t.dll 而非 python313.dll)。为了确保兼容性,扩展模块在构建时必须定义 Py_GIL_DISABLED 宏,否则会导致运行时错误。

问题表现

当开发者使用自由线程版本的 Python(如通过 python313t)构建和导入扩展模块时,如果没有正确定义 Py_GIL_DISABLED 宏,扩展模块会链接到错误的 DLL(python313.dll 而非 python313t.dll),导致段错误(segmentation fault)。

技术分析

在 Windows 平台上,由于共享相同的头文件目录,pyconfig.h 文件无法自动区分常规构建和自由线程构建。因此,构建系统需要显式地定义 Py_GIL_DISABLED 宏来指示当前正在构建自由线程兼容的扩展。

这个问题在 Unix 类系统上不会出现,因为在这些系统上,自由线程构建会生成不同的 pyconfig.h 文件。但在 Windows 上,由于安装程序的限制,开发者必须手动定义这个宏。

解决方案

setuptools 社区已经意识到这个问题,并提出了解决方案。正确的做法是:

  1. 检查 sysconfig.get_config_var("Py_GIL_DISABLED") 的值
  2. 如果返回 True,则在构建扩展时自动添加 -DPy_GIL_DISABLED=1 编译选项

对于使用 setuptools 构建扩展的开发者,目前可以采取以下临时解决方案:

# 在 setup.py 中添加以下代码
import os
import sysconfig

if os.name == 'nt' and sysconfig.get_config_var("Py_GIL_DISABLED"):
    macros.append(('Py_GIL_DISABLED', 1))

未来改进

setuptools 计划在未来版本中自动处理这个问题,使得开发者无需手动添加上述代码。这一改进将遵循与 CMake 类似的逻辑:当链接的导入库名称以 "t.lib" 结尾时(如 python313t.lib),自动定义 Py_GIL_DISABLED 宏。

总结

对于在 Windows 平台上使用 Python 3.13 自由线程版本构建 C 扩展的开发者来说,正确处理 Py_GIL_DISABLED 宏是确保扩展模块正常工作的关键。虽然目前需要手动处理,但 setuptools 正在积极改进以提供更好的开发者体验。

登录后查看全文
热门项目推荐

项目优选

收起
kernelkernel
deepin linux kernel
C
24
7
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
9
1
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
1.03 K
477
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
375
3.21 K
pytorchpytorch
Ascend Extension for PyTorch
Python
169
190
flutter_flutterflutter_flutter
暂无简介
Dart
615
140
leetcodeleetcode
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
62
19
cangjie_compilercangjie_compiler
仓颉编译器源码及 cjdb 调试工具。
C++
126
855
cangjie_testcangjie_test
仓颉编程语言测试用例。
Cangjie
36
852
ops-mathops-math
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
647
258