97. 在LotusScript中模拟函数式编程

2024-02-01 18:38

本文主要是介绍97. 在LotusScript中模拟函数式编程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本文将介绍96. 通用字段修改器用到的在LotusScript中模拟函数式编程的技巧。

函数式编程

函数式编程是一种优美而强大的编程范式。它源于Alonzo Church提出的λ演算(Lambda演算),而某个问题能表示成Lambda演算,按照Church–Turing论题,等价于该问题在数学上是可以有效计算的。粗略地说,用对应于Lambda演算的一门函数式程序语言可以写出任何理论上可计算问题的计算程序。因为与可计算理论的紧密关系和强大的表现力,函数式编程在学术界历来很受重视。但是在日常应用的软件产业,它的声名和流行程度就远不及命令式和面向对象的编程范式。不过近年来随着Erlang、Clojure等函数式编程语言的崭露头角,以及JavaScript、Scala、Python等混合范式编程语言中函数式编程的应用,函数式编程越来越受到业界主流的注意和推广。微软在.Net平台上推出了F#,Java也引进了Lambda表达式。
与一般程序员熟悉的命令式编程相比,函数式编程有以下几个主要特色:
- 函数是一级(first-class)对象。意味着函数与其他普通数据类型的值一样,能够被赋予变量,作为参数传给其他函数,作函数的返回值。
- 尽量避免函数的副作用。即某个函数运算用到的所有外部数据都以参数传入,结果以返回值传出,而不读取和修改外部公共变量。
- 更多使用递归,少用循环。
- 往往涉及大量的列表(list)计算。
下面用既能进行命令式编程又能进行函数式编程的JavaScript的一个简单例子来演示两者之间的差别。把一个包含数字的数组中的每个元素变成其平方。
命令式:

var list=[1, 2, 3, 4, 5];
function square(source){for (i=0; i<source.length; i++){source[i]*=source[i]}
}
square(list);

函数式:

var list=[1, 2, 3, 4, 5];
list=list.map(function(elem){return elem*elem;}
);

习惯于命令式编程的人起初或许会对函数式编程的思路和表达方式感到有些古怪和不适应,但一旦熟悉了,就会喜欢它的方便简捷和强大。比如上面的例子,JavaScript数组的map方法是函数式编程语言列表对象常有的工具,功能是返回一个新的列表,其中每个元素都是将原列表的对应元素传入参数中的函数得到的返回值。这样省去了命令式编程中每当需要处理列表中元素所需的循环套路,只需给出核心的“业务逻辑”——求平方的算法。实际上即使在传统的命令式编程语言中,也常常有传递某个函数的需要。事件式编程的核心就是在事件发布者和订阅者之间传递事件处理程序,或者换个术语回调函数。C有函数指针,.Net平台的语言有代理,Java程序的最小单元是类,所以为了传递一个函数也只能将其包装在一个类中。

在LotusScript中模拟函数式编程

LotusScript中的函数也不能独立地传递,为了模拟,我们只能利用作为一种脚本语言它可以在程序中将一段字符串解释执行的能力。在为自定义对象模拟事件时,我们已经应用了这一技巧。这里我们再用它来模拟函数式编程。

'Operate on an element in an array. Used by ArrayMap.
Private Function Operate(obj As Variant, op As String)'Operates on an objectExecute_Access=objDim pre As String, post As String, pos As Integer If Not StrContains(op,"(") Thenop=op & "()"End IfDim pairspairs=Split("():(,:,):,,",":")Dim pair As String ForAll p In pairspair=CStr(p)If StrContains(op,pair) Thenpos=InStr(op,pair)pre=Left(op,pos)post=Mid(op,pos+1)Exit ForAllEnd If      End ForAllIf pre><"" ThenDim script As Stringscript={Execute_Access=} & pre & {Execute_Access} & post'script="Execute_Access=StrRight(Execute_Access,"""")"'StopExecute(script)Operate=Execute_AccessEnd If
End Function

在上面这个函数中,我们把作为参数传入的op解释成一个函数,应用在另一个参数obj上。Operate函数所在的脚本库的公共变量Execute_Access被用来在Execute函数中读取和写入值。为了使op还能包含它对应的函数本身的参数,如传入{StrRight(,|”|)}字符串对应StrRight函数和|”|参数,Operate对op可能包含的括号和逗号做了一些处理。有了Operate函数做基础,我们就可以模拟上述的map方法:

Function ArrayMap(arr As Variant, op As String) As Variant'operates on each element in an arrayIf IsArray(arr) ThenDim result() As VariantDim lb As Integer, ub As Integerlb=LBound(arr)ub=UBound(arr)ReDim result(lb To ub)Dim i As IntegerFor i=lb To ubresult(i)=Operate(arr(i), op)NextArrayMap=result     End If
End Function

在96. 通用字段修改器给出的代码末端,我们看到频繁使用ArrayMap函数,这种风格使得对数组元素的多次处理显得逻辑清晰,如果改用传统的循环来编写,不仅代码会长很多,也更难于理解和维护。

这篇关于97. 在LotusScript中模拟函数式编程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/668113

相关文章

C语言字符函数和字符串函数示例详解

《C语言字符函数和字符串函数示例详解》本文详细介绍了C语言中字符分类函数、字符转换函数及字符串操作函数的使用方法,并通过示例代码展示了如何实现这些功能,通过这些内容,读者可以深入理解并掌握C语言中的字... 目录一、字符分类函数二、字符转换函数三、strlen的使用和模拟实现3.1strlen函数3.2st

MySQL中COALESCE函数示例详解

《MySQL中COALESCE函数示例详解》COALESCE是一个功能强大且常用的SQL函数,主要用来处理NULL值和实现灵活的值选择策略,能够使查询逻辑更清晰、简洁,:本文主要介绍MySQL中C... 目录语法示例1. 替换 NULL 值2. 用于字段默认值3. 多列优先级4. 结合聚合函数注意事项总结C

CSS模拟 html 的 title 属性(鼠标悬浮显示提示文字效果)

《CSS模拟html的title属性(鼠标悬浮显示提示文字效果)》:本文主要介绍了如何使用CSS模拟HTML的title属性,通过鼠标悬浮显示提示文字效果,通过设置`.tipBox`和`.tipBox.tipContent`的样式,实现了提示内容的隐藏和显示,详细内容请阅读本文,希望能对你有所帮助... 效

Java8需要知道的4个函数式接口简单教程

《Java8需要知道的4个函数式接口简单教程》:本文主要介绍Java8中引入的函数式接口,包括Consumer、Supplier、Predicate和Function,以及它们的用法和特点,文中... 目录什么是函数是接口?Consumer接口定义核心特点注意事项常见用法1.基本用法2.结合andThen链

MySQL 日期时间格式化函数 DATE_FORMAT() 的使用示例详解

《MySQL日期时间格式化函数DATE_FORMAT()的使用示例详解》`DATE_FORMAT()`是MySQL中用于格式化日期时间的函数,本文详细介绍了其语法、格式化字符串的含义以及常见日期... 目录一、DATE_FORMAT()语法二、格式化字符串详解三、常见日期时间格式组合四、业务场景五、总结一、

golang panic 函数用法示例详解

《golangpanic函数用法示例详解》在Go语言中,panic用于触发不可恢复的错误,终止函数执行并逐层向上触发defer,最终若未被recover捕获,程序会崩溃,recover用于在def... 目录1. panic 的作用2. 基本用法3. recover 的使用规则4. 错误处理建议5. 常见错

Python itertools中accumulate函数用法及使用运用详细讲解

《Pythonitertools中accumulate函数用法及使用运用详细讲解》:本文主要介绍Python的itertools库中的accumulate函数,该函数可以计算累积和或通过指定函数... 目录1.1前言:1.2定义:1.3衍生用法:1.3Leetcode的实际运用:总结 1.1前言:本文将详

轻松上手MYSQL之JSON函数实现高效数据查询与操作

《轻松上手MYSQL之JSON函数实现高效数据查询与操作》:本文主要介绍轻松上手MYSQL之JSON函数实现高效数据查询与操作的相关资料,MySQL提供了多个JSON函数,用于处理和查询JSON数... 目录一、jsON_EXTRACT 提取指定数据二、JSON_UNQUOTE 取消双引号三、JSON_KE

MySQL数据库函数之JSON_EXTRACT示例代码

《MySQL数据库函数之JSON_EXTRACT示例代码》:本文主要介绍MySQL数据库函数之JSON_EXTRACT的相关资料,JSON_EXTRACT()函数用于从JSON文档中提取值,支持对... 目录前言基本语法路径表达式示例示例 1: 提取简单值示例 2: 提取嵌套值示例 3: 提取数组中的值注意

C#多线程编程中导致死锁的常见陷阱和避免方法

《C#多线程编程中导致死锁的常见陷阱和避免方法》在C#多线程编程中,死锁(Deadlock)是一种常见的、令人头疼的错误,死锁通常发生在多个线程试图获取多个资源的锁时,导致相互等待对方释放资源,最终形... 目录引言1. 什么是死锁?死锁的典型条件:2. 导致死锁的常见原因2.1 锁的顺序问题错误示例:不同