是否存在与Perl或Ruby中的触发器运算符等效的函数式编程概念?

前端之家收集整理的这篇文章主要介绍了是否存在与Perl或Ruby中的触发器运算符等效的函数式编程概念?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
Ruby(和Per​​l)有一个触发器的概念:
file = File.open("ordinal")
while file.gets
  print if ($_ =~ /third/) .. ($_ =~ /fifth/)
end

给出了一系列序数,例如

first
second
third
fourth
fifth
sixth

当它达到“第三”时开始打印,当达到“第五”时停止打印:

third
fourth
fifth

是否存在类似于此的函数式编程概念,或者通常用takewhiles来描述?我不是在问一个特定的语言,而是用什么术语来形容它.

解决方法

在像haskell这样的函数式语言中,你可以将翻转和翻转条件作为谓词传递,并根据它过滤输入列表.例如,以下是haskell中触发器的定义(如果你不知道haskell,请不要担心实现 – 关键部分是如何使用它):
flipflop flip flop = 
  uncurry (++) . second (take 1) . break flop . dropWhile (not . flip)

这是如何使用它:

> flipflop (== 3) (== 5) [1..10]
[3,4,5]

这是通过使用更高阶函数来制作有效的新语言构造的一个例子.

我不知道在功能语言中是否有该特殊名称.

猜你在找的Perl相关文章