F#初学笔记08

惰性求值
惰性求值也叫按需调用,是一个演算策略,延迟一个表达式的演算,直到需要用到演算值的时候再演算,同时也避免了重复演算。
惰性求值的好处包括:
避免不必要的计算,提升性能。
可以构造以构造一个无限的数据结构
可以定义控制流的抽象类。
惰性求值由于仅仅在需要的时候才求值,所以它可以缩小内存的访问范围。但是惰性求值处理异常,输入输出的时候却有困难,因为代码操作的顺序无法得知,惰性求值可能引起内存泄漏。
惰性求值和函数式编程关系密切。如果没有语言中没有副作用,编译器或可以自由的选择表达式的演算顺序。F#允许函数有副作用,所以在函数演算时,编译器不可能自由选择,因此,可以说F#有严格的演算顺序,是一个严格的语言。你仍然可以利用惰性求值,但是必选显式表面哪些计算可以延迟,也就是哪些按照惰性的方法来演算。
惰性求值的相对的就是及早求值(Eager evaluation),也称严格求值。

 
使用关键字lazy来延时计算,延迟计算的表达式一直不演算,直到显式的对其使用force函数。当force函数用于由于惰性表达式,值就马上计算,结果会被缓存起来。后面再调用force函数,则返回这个缓存值,即使可能引起异常。
下面的代码演示了惰性求值。

 
let lazyValue = lazy ( 2 + 2 )
let actualValue = Lazy.force lazyValue
printfn "%i" actualValue

 
第一行延迟计算了一个简单表达式,下一行强制计算,最终,打印出值。
这个值被缓存了,所以这个值仅在第一次强制惰性求值的时候计算,这很容易演示,如下:

 
let lazySideEffect =lazy(   let temp = 2 + 2printfn "%i" temptemp )
printfn "Force value the first time: "
let actualValue1 = Lazy.force lazySideEffect
printfn "Force value the second time: "
let actualValue2 = Lazy.force lazySideEffect

上例中,强制计算2次值,但是此副作用值发生一次。运行结果如下:

 

惰性求值在操作集合的时候很有用,惰性集合的概念就是集合中的元素仅在需要的时候才计算。一些集合类型也会缓存计算结果,所以也不需要重复计算元素。

注意,此处用 Lazy.force因为作者可能使用的OCaml,在F#从 OCaml 风格转到C#风格之前。现在用x.Value 或者x.Force()替代。由于某些原因F#现在在PowerPack中。F# PowerPack是由微软的F#团队提供的编译器和核心库。http://fsharppowerpack.codeplex.com/

创建惰性集合,最重要也是最难的可能要数unfold。此函数允许你建立惰性List。难点在于你必须提供一个函数,此函数用于重复计算以提供元素。这个传递给Seq.unfold的函数可以接受任何类型的参数,并且必须返回一个option类型。option类型是一个union类型,可以是None或者Some(x),x是任何类型的值。None代表list的结束。Some 结构必须包含一个元组。第一个元素是list中的第一个值,第二个值是下一次调用的时候要传给函数的值。你可以认为这个值是一个累加器。

 
看一个例子就明白,标识符lazyList,如果传递给函数的值小于13,追加到list,然后把值加1传递给list。这个值将是下一次调用的时候传递给函数的。如果这个值大于等于12,返回None,终结这个list。

 
// the lazy list definition
let lazyList =Seq.unfold(fun x ->if x < 13 then// if smaller than the limit return// the current and next valueSome(x, x + 1)else// if great than the limit// terminate the sequenceNone)10
// print the results
printfn "%A" lazyList
结果就是 10,11,12
Sequences用来表示list,如果内存无限多,那么也就可以有无限多元素。下面的例子演示创建一个Fibonacci数列。由于使用了bigint,不受32-bit整型限制,可以计算更多的数字。为了演示方便,使用函数 Seq.take返回前20个元素到F#的list中。

 
// create an infinite list of Fibonacci numbers
let fibs =Seq.unfold(fun (n0, n1) ->Some(n0, (n1, n0 + n1)))(1I,1I)
// take the first twenty items from the list
let first20 = Seq.take 20 fibs
// print the finite list
printfn "%A" first20
计算结果:
[1I; 1I; 2I; 3I; 5I; 8I; 13I; 21I; 34I; 55I; 89I; 144I; 233I; 377I; 610I; 987I;
1597I; 2584I; 4181I; 6765I]

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/404013.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

JAVA进阶day05包和权限

我这种外行人也听说过jar包&#xff0c;jar到底是个啥&#xff1f;为啥c语言里没有呢&#xff1f;下面我们拨开这一层面纱。贴代码做分析&#xff1a; 一、jar包 import a.b.c.d1.*; import a.b.c.d2.*;public class Pack {public static void main(String args[]) {/* add *…

为Mac安装homebrew

参考&#xff1a;http://brew.sh/index_zh-cn.html 以下是我的具体执行过程: zcms-iMac:~ zcm$ ruby -e "$(curl -fsSL https://raw.github.com/Homebrew/homebrew/go/install)" > This script will install: /usr/local/bin/brew /usr/local/Library/... /usr/…

springmvc在启动工程的时候就访问数据库,加载一些共同的数据

在网上找到一个类似的问题&#xff0c;稍做修改 解决方案&#xff1a;给web容器添加一个Listener类&#xff0c;在容器启动的时候执行Listener的“初始化”方法&#xff0c;在这个初始化方法中执行查询数据库的所有操作&#xff0c;然后将数据库中的信息缓存起来 问题&#xff…

如何用组策略来找到丢失的文件

在Windows的域中通过组策略来“重定向我的文档”&#xff0c;对于系统管理员来说是一项非常有用的工具。它可以帮助管理员们解决大多数的关于丢失文件和文件夹的灾难。这些灾难包括不正确的存储&#xff0c;一个已经被破坏了的文件或者是一次彻底的删除。不幸的是&#xff0c;我…

JAVA进阶day06内部类和匿名类

内部类分为一般内部类和静态内部类&#xff0c;下面贴代码分析&#xff1a; class Outer {private int a 10;class Inner {public void printInfo(){System.out.println("a "a);}}}public class InnerDemo {public static void main(String args[]) {Outer o new…

在Finder标题栏上显示完整路径

From: http://www.7do.net/resources-5411-1-1.html 打开终端&#xff0c;输入以下命令并回车&#xff1a; defaults write com.apple.finder _FXShowPosixPathInTitle -bool YES 然后再把finder关了再打开&#xff0c;你会发现路径栏变成这个样子了&#xff1a; 其实呢&a…

Wamp5 配置PHP 图文详解(转)

Wamp5论坛配置图文版 知识扫盲&#xff1a; 1、WampSever指的是apache mySQL PHP三合一套装&#xff0c;第一字母W&#xff0c;是指用于windows系统&#xff0c;我用的是2.0f版。用于Linux系统的&#xff0c;是LampSever&#xff0c;第一字母是L。 下载地址http://jaist.dl.s…

JAVA进阶day07JNI(java调用c)A部分

目前接触的JNI有java调用c和c调用java两类。其中java调用c又有隐式和显示两种映射关系。本笔记针对java调用c的显示映射。本着工程实际够用的原则&#xff0c;不够再回头来补充。 JAVA访问c库需要有三个步骤 1&#xff1a;加载C库 2&#xff1a;建立java函数名到c库函数名的…

理解线程的挂起,sleep还有阻塞

线程是靠cpu来运行的&#xff0c;cpu要运行一个线程&#xff08;不说别的&#xff09;最起码就是要占用cpu时间&#xff0c;象Windows这样的多任务操作系统&#xff0c;可以允许多个线程同时运行&#xff0c;所谓的同时运行并不是真正的同时运行&#xff0c;而是轮流运行不同的…

9个小窍门让OS X中Finder用起来更顺手

From: http://digi.tech.qq.com/a/20130309/000051.htm 腾讯数码讯&#xff08;编译&#xff1a; 李斯特&#xff09;Finder是OS X系统上用户与文件系统打交道的主要途径之一&#xff0c;它的默认设置是能满足普通用户绝大多数日常需求的。但我们同样可以通过一些小配置来使它…

JAVA进阶day07JNI(java调用c)B部分

本博文要做两件事 1&#xff1a;怎样将c文件编译成lib*.so 2:java同c语言文件如何传递返回数据类型 现在开始搞起&#xff1a; 1&#xff1a;怎样将c文件编译成lib*.so Linux下编译共享库时&#xff0c;必须加上-fPIC参数&#xff0c;否则在链接时会有错误提示。故而我们的…

DataGridView设置行高

RowTemplate.height50; 其他默认

xcode-select: error: tool 'xcodebuild' requires Xcode错误解决方法

From: http://blog.csdn.net/jymn_chen/article/details/21613745 因为机子里有两个Xcode&#xff0c;所以分别重命名了&#xff0c;但是在运行一个MakeFile时却报了以下错误&#xff1a; [plain] view plaincopyxcodebuild -target "GHUnitIOS (Device)" -configu…

Struts2_模块包含 及Action总结

模块包含 做项目时&#xff0c;当Struts配置文件比较多&#xff0c;需要模块化划分或分开成为多个配置文件时&#xff0c;公共配置放在struts.xml,其余有各自的xml文件&#xff0c;后使用<include>标签把其它的配置文件引入到Struts.xml配置文件中就可以了。 默认Action …

JAVA进阶day08泛型

写这篇博文&#xff0c;我并没有特别大的把握。姑且贴代码做分析。遇到什么知识点分析什么知识点吧。 class Person<T> {private T age;public void setAge(T age) {this.age age;}public T getAge() {return this.age;} }public class Generics {public static void ma…

http://www.iteye.com/topic/114392

http://www.iteye.com/topic/114392 http://wiki.jabbercn.org/RFC6120#STARTTLS.E5.8D.8F.E5.95.86 2.如果初始化实体有能力使用SASL 协商, 它必须&#xff08;MUST&#xff09;在初始化流的头信息中包含一个值为"1.0"的属性version。 STARTTLS扩展的XML命名空间是 …

Python模块——_winreg操作注册表

From: http://blog.sina.com.cn/s/blog_4b5039210100gmsb.html 用python操作修改windows注册表&#xff0c;显然要比用C或者C简单。 主要参考资料&#xff1a;官方文档&#xff1a;http://docs.python.org/library/_winreg.html 通过python操作注册表主要有两种方式&#xff…

AS查看Android系统源码

首先要编译安卓源码。我现在使用的是Android5.0源码。平台是tiny4412平台。 一. 编译Android 系统 进入上述解压得到的android-5.0.2&#xff0c;执行以下命令(注意&#xff1a;“.”号后有一个空格)&#xff1a; .setenv再执行“lunch”命令&#xff0c;输入“fulltiny4412…

利用Bdrive打造个人私有云存储解决方案

Bdrive 一款私有云储存软件&#xff0c;可以自己方便的在 Mac/Windows 下架设服务器&#xff0c;并可以通过 PC、Mac、iOS、Android 跨平台使用。以下简单介绍一下利用Bdrive来完成个人私有云存储解决方案。 第一步&#xff0c;搭建Bdrive云存储服务器 先下载Bdrive服务器程序&…

MVC路由中routes.IgnoreRoute({resource}.axd/{*pathInfo}) 到底什么意思!

转自&#xff1a;http://blog.csdn.net/lvjin110/article/details/24638913 参考&#xff08;1&#xff09; http://www.cnblogs.com/flyfish2012/archive/2013/02/01/2889184.html 我们在开发MVC当中&#xff0c;经常在我们的全局类的路由设置&#xff0c;看到这样的代码&…