gpt4 book ai didi

haskell - 有没有办法在运行时在 GHC 中确定抽象值是否是函数?

转载 作者:行者123 更新时间:2023-12-04 15:20:26 27 4
gpt4 key购买 nike

我想知道是否有可能具有如下功能(有点类似于 dataToTag# ):

isFunction# :: a -> Bool

或可能等效地:
isFunction# :: Any -> Bool

返回 True如果作为参数传入的值是 a -> b 类型(或者,就此而言, a => b )在运行时对于某些类型 ab , 或 newtype其基础类型是(因此它“看穿” newtype s,但当然不是 data ),而不强制其论点。我在 GHC.Prim 中没有看到类似的内容我自己,但我可能错过了一些东西,或者可能使用手动 CMM primop 或其他东西。

既然我想到了这个问题,我就对答案本身感到好奇( question Y),但我想到它的最初原因(问题 X)是投诉通常针对 seq。是它打破了 eta 等价性,可以观察 undefined 之间的差异。和 \_ -> undefined , 我想知道是否可以制作 seq 的版本( myseq a = if isFunction# a then flip const a else seq a )仍然是“神奇的多态”(工作 forall a ),但只是不理会函数。

最佳答案

不,肯定不是。如果不评估论证,它怎么能知道呢?

但要直接解决您的问题 X,您建议的 myseq比真实的更差seq因为它打破了参数化。是 myseq undefined :: b -> b底,还是身份?取决于类型变量a ( undefined :: a ) 是否使用函数类型进行实例化。

在 Haskell 中,您总是可以删除 forall a.a由于参数化,根本没有出现在类型中:a 的选择没关系。您的 myseq将失去该属性(property)。

这也是您无法实现 isFunction# 的原因。没有在运行时用它们的预期类型注释值(isFunction# undefined 同样没有意义)。

关于haskell - 有没有办法在运行时在 GHC 中确定抽象值是否是函数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33765355/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com