本系列学习在.NET中的并发并行编程模式,实战技巧

函数式编程

和面向过程编程POP(procedure oriented Programming)面向对象编程OOP(object oriented programming)一样也是一种编程思维。函数式编程FP(functional programming)和面向过程比较类似,但它更加抽象。

举个栗子
五子棋,用面向过程编程开发流程就是: ①开始游戏->②黑子先走->③绘制局势->④判断输赢->⑤轮到白子->⑥绘制局势->⑦判断输赢->⑧返回步骤②->⑨输出结果,每一步骤写成单独的函数就是面向过程的编程思维。优点逻辑很清晰,较少的抽象。

面向对象编程可以从另外一个角度来解决这个问题,本质就是按功能角色划分,将不同的函数封装到不同的对象中。黑白双方一个对象,棋盘对象用于绘制棋盘局势,规则对象用于判断输赢是否五子连心。各个对象之间互相通知,互相协调。优点维护修改方便,如果换成围棋,直接修改规则对象判断棋子是否还有“气”,或者通过面向对象特性去扩展一个对象。理解起来可能比较困难,实际代码执行可能分散到太多分支上。

面向函数编程呢?函数也是一个独立的存在,它可以像变量一样在任何地方出现。因为在面向过程中,不需要将函数做当方法来调用,直接在过程中调用,像Lambda表达式,对一个集合进行快速处理,不需要额外增加方法,调用出编写一个临时函数即可。

函数

先思考一个问题,函数一定要当做方法放在一个对象中吗?答案是否定的,函数并不属于对象,它是独立的。在函数式编程思维里,函数可以通过变量,参数等方式传递到任何地方,可以在任何地方被调用,它和基本数据类型的待遇一样。函数式语言一直以来都比较低调,直到并发计算编程瓶颈的出现。

实现并发

并发容易造成什么问题?从单线程到多线程中,共享状态的变化容易不受控制。传统的解决方案就是同步对资源的访问,避免线程之间的争用。这样也不是万全之策,同步访问互斥锁容易出现竞态和死锁。根本的解决方案应该是不依赖于这些变量,既然是变量,就不能依赖于它的状态。

FP在并发编程上的优势

  • 不可变性。在FP中没有变量赋值的概念。对象一旦确定值就不可更改,这在线程之间可以安全的传输。

  • 纯函数。函数不会修改函数体之外的任何类型的输入或数据,也就是纯函数,没有副作用(副作用就是相同的输入可能产生不同的输出)。输出取决于输出,相同的参数传递给纯函数,输出只会是相同的值,产生一致的预期行为。

  • 延迟计算。在FP中按需检索函数的结果,或将大数据流的分析推迟到需要时。

  • 可组合性。组合函数创建更高级的抽象,有利用解决复杂问题。

NULL值的错误

高级语言一般都有NULL值类型。Tony Hoare在1965年设计ALGOL面向对象语言时引入了null引用。大约44年后,他为发明他道歉,称它是10亿美元的错误。

我无法抗拒引入null引用的诱惑,因为它非常容易实现。这导致了无数的错误、漏洞和系统崩溃。

F#是.NET语言的一部分,是一种函数式编程语言。它就强烈反对null值,鼓励使用不可变的数据结构,天生适用于并发。C#是在.NET3.5之后也引入函数式范式,增加了诸如lambda表达式和LINQ之类的列表解析功能。因为都在.NET平台上,F#和C#可以互操作,互相调用,有些复杂场景用F#可以用更简易的方式实现。

to be contiued!
下集:并发函数式编程技术

写给普通:

人一旦得到一样东西
就会忘记当初趴在橱窗看它的感觉

.NET并发编程-函数式编程的更多相关文章

  1. javascript 函数式编程

    编程范式 编程范式是一个由思考问题以及实现问题愿景的工具组成的框架.很多现代语言都是聚范式(或者说多重范式): 他们支持很多不同的编程范式,比如面向对象,元程序设计,泛函,面向过程,等等. 函数式编程 ...

  2. 【大前端攻城狮之路】JavaScript函数式编程

    转眼之间已入五月,自己毕业也马上有三年了.大学计算机系的同学大多都在北京混迹,大家为了升职加薪,娶媳妇买房,熬夜加班跟上线,出差pk脑残客户.同学聚会时有不少兄弟已经体重飙升,开始关注13号地铁线上铺 ...

  3. [一] java8 函数式编程入门 什么是函数式编程 函数接口概念 流和收集器基本概念

      本文是针对于java8引入函数式编程概念以及stream流相关的一些简单介绍 什么是函数式编程?   java程序员第一反应可能会理解成类的成员方法一类的东西 此处并不是这个含义,更接近是数学上的 ...

  4. Java函数式编程和lambda表达式

    为什么要使用函数式编程 函数式编程更多时候是一种编程的思维方式,是种方法论.函数式与命令式编程的区别主要在于:函数式编程是告诉代码你要做什么,而命令式编程则是告诉代码要怎么做.说白了,函数式编程是基于 ...

  5. swift之函数式编程

    函数式编程初探 最近初学swift,和OC比,发现语言更现代,也有了更多的特性.如何写好swift代码,也许,熟练使用新特性写出更优秀的代码,就是答案.今天先从大的方向谈谈swift中的编程范式-函数 ...

  6. 关于函数式编程(Functional Programming)

    初学函数式编程,相信很多程序员兄弟们对于这个名字熟悉又陌生.函数,对于程序员来说并不陌生,编程对于程序员来说也并不陌生,但是函数式编程语言(Functional Programming languag ...

  7. Scala函数与函数式编程

    函数是scala的重要组成部分, 本文将探讨scala中函数的应用. scala作为支持函数式编程的语言, scala可以将函数作为对象即所谓"函数是一等公民". 函数定义 sca ...

  8. 函数式编程(Function Program Language)

    WHAT: 简单说,"函数式编程"是一种"编程范式",也就是如何编写程序的方法论. 它属于"结构化编程"的一种,主要思想是把运算过程尽量写成 ...

  9. Python学习(26):Python函数式编程

    转自  http://www.cnblogs.com/BeginMan/p/3509985.html 前言 <core python programming 2>说: Python不大可能 ...

随机推荐

  1. 在搜索引擎中输入汉字就可以解析到对应的域名,请问如何用LoadRunner进行测试。

    建立测试计划,确定测试标准和测试范围 设计典型场景的测试用例,覆盖常用业务流程和不常用的业务流程等 根据测试用例,开发自动测试脚本和场景: 录制测试脚本:新建一个脚本(Web/HTML协议):点 ...

  2. 数据库事务特性ACID

    事务 事务(Transaction),一般是指要做的或所做的事情.在计算机术语中是指访问并可能更新数据库中各种数据项的一个程序执行单元(unit).在计算机术语中,事务通常就是指数据库事务. 概念 一 ...

  3. Spring Cloud Hystrix原理篇(十一)

    一.Hystrix处理流程 Hystrix流程图如下: Hystrix整个工作流如下: 构造一个 HystrixCommand或HystrixObservableCommand对象,用于封装请求,并在 ...

  4. 「译」用 Blazor WebAssembly 实现微前端

    原文作者: Wael Kdouh 原文链接:https://medium.com/@waelkdouh/microfrontends-with-blazor-webassembly-b25e4ba3f ...

  5. Spring Boot 2.x基础教程:实现文件上传

    文件上传的功能实现是我们做Web应用时候最为常见的应用场景,比如:实现头像的上传,Excel文件数据的导入等功能,都需要我们先实现文件的上传,然后再做图片的裁剪,excel数据的解析入库等后续操作. ...

  6. Codeforces Round #695 (Div. 2)

    比赛地址 A (水题) 题目链接 题目: 给出\(n\)个面板,每个面板初始时间相同,每过1s面板上数字会加1(数字在\(0\sim9\)循环播放),任意时刻选择一个面板\(x\)使他的时间停止,其他 ...

  7. win安装python模块出现依赖问题的解决方法 & No module named 'MySqldb'

    前言 一年多了,还在写这种问题,羞愧. 新公司不让用自己的电脑,配的winPC,项目启不起来,之前也出现过这个问题,是py3缺少某个模块,但是自己没记,这次记一下好了. No module named ...

  8. 浅谈TypeScript,配置文件以及数据类型

    TypeScript在javaScript基础上多了一些拓展特性,多出来的是一些类型系统以及对ES6新特性的支持最终会编译成原始的javaScript, 文件名以.ts结尾,编译过后.js结尾,在an ...

  9. mmall商城购物车模块总结

    购物车模块的设计思想 购物车的实现方式有很多,但是最常见的就三种:Cookie,Session,数据库.三种方法各有优劣,适合的场景各不相同.Cookie方法:通过把购物车中的商品数据写入Cookie ...

  10. TCP/IP五层模型-应用层-DNS协议

    ​1.定义:域名解析协议,把域名解析成对应的IP地址. 2.分类:①迭代解析:DNS所在服务器若没有可以响应的结果,会向客户机提供其他能够解析查询请求的DNS服务器地址,当客户机发送查询请求时,DNS ...