簡體   English   中英

作為Haskell中的(@)模式

[英]As (@) pattern in Haskell

我在Haskell中編寫了自己的take函數,如下所示:

take' :: (Integral n, Eq a) => n -> [a] -> [a]
take' n lst
    | n <= 0 = []
    | lst == [] = []
    | otherwise = (head lst) : (take' (n-1) $ tail lst)

而且運作良好。

但是當我嘗試在函數參數中使用as(@)模式編寫相同的函數時,似乎該函數無法識別第二個guard選項:

take' :: (Integral n, Eq a) => n -> [a] -> [a]
take' n lst@(hd:tl)
    | n <= 0 = []
    | lst == [] = []
    | otherwise = hd : (take' (n-1) $ tl)

當我嘗試在ghci中取'20 take' 20 [] ,我得到Non-exhaustive patterns in function take'Non-exhaustive patterns in function take'錯誤。

我究竟做錯了什么?

謝謝,Špela。

看這里:

lst == [] = []

lst永遠不能等於[] ,因為你說lst = hd:tl 相反,你可以打破那個分支,進入一個獨立的模式匹配,以獲得完全覆蓋。 (一旦這樣做,您也可以刪除Eq約束。)

當你調用'20 take' 20 [] ,它會嘗試找到一個與之匹配的模式,但你沒有寫一個: hd:tl不能與[]匹配。 在模式無法匹配之后,它不會看到該模式的守衛。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM