您好,登錄后才能下訂單哦!
C++模版編程實現Haskell的函數模式匹配特性[圖]:
大神 Bartosz Milewski 在2009年寫了一篇文章《What Does Haskell Have to Do with C++?》,使用C++實現Haskell函數式編程語言的一些特性。【傳送門在文末】
其中有這樣一段例子:
// code 1
1.template<int n>class fact {
2.public:
6.template<>class fact<0>{// specialization for n = 0
7.public:
/ 第6行代碼是“特化”類模版fact,
也就是顯式地給出某種類型參數的
類模板的一個實例的代碼,而非由
編譯器生成。
在這里,是給出了參數n為0時模板
fact的代碼。這樣,編譯器不會再
根據類模版fact生成n=0時的代碼
關于模版特化,詳見文末鏈接
/
6.template<>class fact<0>{// specialization for n = 0
7.public:
當程序員調用【fact 8】的時候(參數是8,因為Haskell函數調用一般不像C++那樣給參數加括號),Haskell會將之匹配到上面代碼的第2行。誰動了我的奶酪讀書筆記(http://www.simayi.net/dushubiji/6208.html)摘抄好詞好句及感悟賞析,這種參數匹配,是Haskell特有的函數聲明與調用方式。
所以前面的code1中C++模版代碼,就是在模仿 code4 中的Haskell代碼。
下面給出一個完整的Haskell程序
moduleFactwhere
importSystem.IO
fact::Integer->Integer
fact0=1
fact n = n * fact (n-1)
main::IO()
main=do
putStrLn $"8! = "++ show (fact 8)
putStrLn $"88! = "++ show (fact 88)
上面的代碼輸出結果是:
8! = 40320
88! =185482642257398439114796845645546284380220968949399346684421580986889562184028199319100141244804501828416633516851200000000000000000000
Haskell對C++說:我能算88!,你行嗎?
C++說:你欺負人!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。