use*_*220 4 pypy hindley-milner rpython
PyPy 是否在编译时进行静态类型检查以在编译时捕获类型错误?如果没有,HM 类型推断之类的东西是否有助于在编译时捕获这些错误?
小智 5
两个账户都没有。(我假设 PyPy 是指具有 JIT 编译器和其他功能的 Python 解释器。)它不会随时对 Python 代码进行静态类型检查,因为它实现的是 Python 语言,而不是类似 Python 的静态类型语言。事实是,您*无法*静态地检测Python程序中的所有类型错误(对于“类型错误”的大多数定义)。您可以尝试找到一些,但即使您可以证明在运行时会发生类型错误,您也不能拒绝执行该程序,因为从其他地方运行该代码并捕获它是完全有效的(有时很有用)例外。
顺便说一句,Damas-Hindley-Milner 推断类型的类型系统甚至远远不足以表达 Python 程序中“类型”的有用子集(并不是说最流行的静态类型系统表现得更好)。例如,尝试键入zip(提示:Haskell 没有它,它有几个专门用于 2、3、4 个参数的函数)。或者,如果你想要更难的东西,getattr. 然后是整个名义和结构子类型的事情。
人们曾尝试在 Python 和类似语言中推断类型,但这些方法必然与函数式编程世界在该领域所做的完全不同(见上文)。此外,这些项目永远不会发现Python程序中的所有类型错误(尽管有些项目已经涵盖了极大简化的子集,或者检测了Python 程序中的一些错误)。做一些研究(Lambda the Ultimate有很多链接)。
现在,“PyPy”这个名称历史上也用于RPython 翻译工具链,它确实可以推断 RPython 程序的静态类型。但 RPython 不是 Python(它有很多很多限制,以至于它实际上是一种不同的语言),并且类型系统和类型推断与 DHM 完全不同(整个程序,基于抽象解释,完全不同)。不同类型的系统)。