gpt4 book ai didi

haskell - 一个覆盖如何显示新类型?

转载 作者:行者123 更新时间:2023-12-04 09:08:04 25 4
gpt4 key购买 nike

我想覆盖 Haskell 中的默认整数构造函数,以便它们生成字符串(主要是为了好奇,但暂时为 LaTeX 的\frac{}{} 不便提供一个不错的输入替代方案)。

我希望能够使用语言本身,而不是特殊的解析器,但我想这可能行不通......

module Main where

import Prelude hiding ((+))

newtype A = A Int deriving (Eq, Show, Num)
default (A)

(+) :: A -> (A -> String)
(A a) + (A b) = (show a) ++ " + " ++ (show b)

main2 = 3+4

main :: IO ()
main = putStrLn main2

上面的问题是 + 函数只适用于 (A, A) 而不是 (A, String) 等。如果简单地省略模式匹配“(A a)”并改为写“a”,那么show() 函数在“A”前面加上“3”,而不仅仅是“3”。

我想覆盖A的Show,但这似乎很头疼......

最佳答案

如果你想要自己的 Show A 的实例,那么就不要派生它并制作自己的实例:

newtype A = A Int deriving (Eq, Num)

instance Show A where
show (A a) = show a

然后你可以写这样的东西:
(+) :: (Show a, Show b) => a -> b -> String
a + b = show a ++ " + " ++ show b

当然,如果您要定义自己的 +像这样的运算符,那么我认为您的问题不需要 newtype A宣言:
module Main where

import Prelude hiding ((+))

(+) :: (Show a, Show b) => a -> b -> String
a + b = show a ++ " + " ++ show b

aSum = 3 + 4

main :: IO ()
main = putStrLn aSum

关于haskell - 一个覆盖如何显示新类型?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2660778/

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