首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >没有实例(Data.Functor.Classes.Show1 ExprF)

没有实例(Data.Functor.Classes.Show1 ExprF)
EN

Stack Overflow用户
提问于 2017-04-23 03:17:15
回答 1查看 1K关注 0票数 7

我编写了一个小程序来寻找一个数字的素因式分解。除了main函数之外,所有东西似乎都是编译的,该函数抱怨无法找到Show1实例。

代码语言:javascript
复制
{-# LANGUAGE DeriveFunctor #-}

module FactorAnamorphism where

import Data.Functor.Foldable
import Data.List

nextPrimeFactor :: Integer -> Maybe Integer
nextPrimeFactor n = find (\x -> n `mod` x /= 0) [2..(floor $ sqrt $ fromIntegral n)]

data ExprF r = FactorF Integer | MultF r r deriving (Show, Functor)
type Expr = Fix ExprF

factor :: Integer -> Expr
factor = ana coAlg where
  coAlg fac = case (nextPrimeFactor fac) of
    Just prime -> MultF prime (fac `div` prime)
    Nothing    -> FactorF fac

main :: IO ()
main = putStrLn $ show $ factor 10

日志:

代码语言:javascript
复制
 % stack build
haskell-playground-0.1.0.0: build (lib + exe)
Preprocessing library haskell-playground-0.1.0.0...
Preprocessing executable 'factor-anamorphism' for
haskell-playground-0.1.0.0...
[1 of 1] Compiling FactorAnamorphism ( app/FactorAnamorphism.hs, .stack-work/dist/x86_64-osx/Cabal-1.24.2.0/build/factor-anamorphism/factor-anamorphism-tmp/FactorAnamorphism.o )

/Users/ian/proj/macalinao/haskell-playground/app/FactorAnamorphism.hs:22:19: error:
    • No instance for (Data.Functor.Classes.Show1 ExprF)
        arising from a use of ‘show’
    • In the second argument of ‘($)’, namely ‘show $ factor 10’
      In the expression: putStrLn $ show $ factor 10
      In an equation for ‘main’: main = putStrLn $ show $ factor 10

--  While building package haskell-playground-0.1.0.0 using:
      /Users/ian/.stack/setup-exe-cache/x86_64-osx/Cabal-simple_mPHDZzAJ_1.24.2.0_ghc-8.0.2 --builddir=.stack-work/dist/x86_64-osx/Cabal-1.24.2.0 build lib:haskell-playground exe:factor-anamorphism exe:haskell-playground-exe --ghc-options " -ddump-hi -ddump-to-file"
    Process exited with code: ExitFailure 1
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-04-23 03:42:04

Show for Fix的实例是:Show1 f => Show (Fix f),这就是编译器期望Show1 ExprF的原因。

Show1可以在Data.Functor.Classes下的base中找到,并且在Text.Show.Deriving中有一个从派生-compat派生它的脚本。

票数 13
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/43567005

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档