2009-01-06 73 views

回答

5

一些想法:

  1. 調試命令行選項(你可以在擁抱:set +d設置)爲信息,但很冗長,不顯示你在Haskell語法的削減。

  2. 嘗試Hat - the Haskell Tracer。我只是嘗試了一個簡單的程序,它非常酷。儘管我不在Windows上,但我不知道讓它運行有多困難。這很可能相當困難,這很令人遺憾,因爲它很酷,基本上就是你想要的。如果你得到它的運行,你可以從紅帽得到這樣的信息:

    main = {IO} 
    teneven = [2,4,6,8,10] 
    _foldr (\..) [1,2,3,4,5,6,7,8, ...] [] = [2,4,6,8,10] 
    (\..) 1 [2,4,6,8,10] = [2,4,6,8,10] 
    (\..) 2 [4,6,8,10] = [2,4,6,8,10] 
    (\..) 3 [4,6,8,10] = [4,6,8,10] 
    (\..) 4 [6,8,10] = [4,6,8,10] 
    (\..) 5 [6,8,10] = [6,8,10] 
    (\..) 6 [8,10] = [6,8,10] 
    (\..) 7 [8,10] = [8,10] 
    (\..) 8 [10] = [8,10] 
    (\..) 9 [10] = [10] 
    (\..) 10 [] = [10] 
    

    拉姆達有even。另外,如果你願意,Hat可以追蹤foldr和其他內部電話的呼叫;默認情況下,它不會這樣做。

+0

不幸的是,帽子似乎沒有在ghc 7.8.3上編譯,開發似乎在2012年11月13日停止。 – 2014-11-24 05:48:37

2

相信我,你不想走這條路。

在每個特定情況下使用的減少集(和順序)將取決於特定的語言實現(擁抱可以做到這一點,ghci - 換句話說,jhc-在另一個方面等)。

更好地閱讀一些有關的一般方式來實現編譯器/解釋/ virual機功能性的語言 - 像SECD機等

幾個環節:

5

這裏有幾個使用Debug.Trace和Hugs.Observe的例子。

import Debug.Trace 
fact :: Integer -> Integer 
fact 0 = trace "fact 0 ->> 1" 1 
fact n = trace ("fact " ++ show n) (n * fact (n-1)) 


import Hugs.Observe 
fact :: Integer -> Integer 
fact 0 = observe "fact 0" 1 
fact n = observe "fact n" (n * fact (n-1)) 

希望這可以幫助您弄清楚如何使用WinHungs打印所有縮小。

相關問題