Java 8 发布带来的一个主要特性就是对函数式编程的支持. 而 Lambda 表达式就是一个新的并且很重要的一个概念. 它提供了一个简单并且很简洁的编码方式. 首先从几个简单的 Lambda 表达式的例子开始了解 Java 中的函数式编程. Lambda 表达式初识: 首先定义一个 Lambda 表达式: x -> x + 1 这个表达式输入参数是一个 x,然后对这个参数 x 的操作是加 1,然后将这个结果返回,即返回值. 从这个简单的 Lambda 表达式可以看出 Lambda 表达式的语法…
写在前面 如果说函数式接口和lambda表达式是Java中函数式编程的基石,那么stream就是在基石上的最富丽堂皇的大厦. 只有熟悉了stream,你才能说熟悉了Java 的函数式编程. 本文主要介绍Stream的基础概念和基本操作,让大家对Stream有一个初步的理解. 本文的示例代码可从gitee上获取:https://gitee.com/cnmemset/javafp stream的概念 首先,看一个典型的stream例子: public static void simpleStream…
写在前面 在本系列文章的第一篇,我们提到了函数式编程的优点之一是"易于并发编程". Java作为一个多线程的语言,它通过 Stream 来提供了并发编程的便利性. 题外话: 严格来说,并发和并行是两个不同的概念. "并发(Concurrency)"强调的是在同一时间开始执行多个任务,通常会涉及多线程之间的上下文切换: "并行(Parallelism)"强调的是将一个大任务分解为多个小任务后,再同时执行这些小任务,得到多个中间结果后再汇总为一个最终…
写在前面 Stream 的 Map-Reduce 操作是Java 函数式编程的精华所在,同时也是最为复杂的部分.但一旦你啃下了这块硬骨头,那你就真正熟悉Java的函数式编程了. 如果你有大数据的编程经验,你会对术语 Map-Reduce 十分熟悉亲切.如果你不熟悉大数据编程,也无所谓,通过本文的学习,相信你会对 Map-Reduce 会有一定的理解.下面我们将开始一次有趣的历程. 如有疑问,欢迎加群讨论. 本文的示例代码可从gitee上获取:https://gitee.com/cnmemset/…
写在前面 前面说过,判断一门语言是否支持函数式编程,一个重要的判断标准就是:它是否将函数看做是"第一等公民(first-class citizens)".函数是"第一等公民",意味着函数和其它数据类型具备同等的地位--可以赋值给某个变量,可以作为另一个函数的参数,也可以作为另一个函数的返回值. Java 8是通过函数式接口,赋予了函数"第一等公民"的特性. 本文将详细介绍Java 8中的函数式接口. 本文的示例代码可从gitee上获取:https…
写在前面 随着Java 8引入了函数式接口和lambda表达式,Java 8中的集合框架(Java Collections Framework, JCF)也增加相应的接口以适应函数式编程.   本文的目标是带领大家熟悉Java 8中集合框架新增的常用接口,让我们的代码更简洁.更高级.   本文的示例代码可从gitee上获取:https://gitee.com/cnmemset/javafp     Java 8中的集合框架 首先,和大家从整体上了解Java集合框架.   Java集合框架,主要是…
写在前面 lambda表达式是一个匿名函数.在Java 8中,它和函数式接口一起,共同构建了函数式编程的框架.   lambda表达式乍看像是匿名内部类的一种语法糖,但实际上,它们是两种本质不同的事物.匿名内部类本质是一个类,只是不需要程序员显示指定类名,编译器会自动为该类取名.而 lambda 表达式本质是一个函数,当然,编译器也会为它取名.在JVM层面,匿名内部类对应的是一个 class 文件,而 lambda 表达式对应的是它所在主类的一个私有方法.   lambda 表达式可以在函数体中…
写在前面 我们已经知道,lambda表达式是一个匿名函数,可以用lambda表达式来实现一个函数式接口.   很自然的,我们会想到类的方法也是函数,本质上和lambda表达式是一样的,那是否也可以用类的方法来实现一个函数式接口呢?答案是可以的.我们称之为方法引用(method reference).   本文的示例代码可从gitee上获取:https://gitee.com/cnmemset/javafp   方法引用 一个典型例子,向一个Map中写入单词以及它的长度: public stati…
函数式编程(Functional Programming) 首先,我们来了解一个叫做"编程范式"的概念. 什么是"编程范式"呢?简单来说就是指导我们编程的方法论,是一种教我们如何编写代码.如何组织代码的"解题"思路. 业界普遍将编程范式划分为两大类:指令式和过程式,当然每个大类也可以接着往下细分,下面只列出了一些比较常见的子分类: 指令式(Imperative) 过程式(Procedural),比如:Fortran.C 面向对象(Object O…
Socket,又称为套接字,Socket是计算机网络通信的基本的技术之一.如今大多数基于网络的软件,如浏览器,即时通讯工具甚至是P2P下载都是基于Socket实现的.本文会介绍一下基于TCP/IP的Socket编程,并且如何写一个客户端/服务器程序. 餐前甜点 Unix的输入输出(IO)系统遵循Open-Read-Write-Close这样的操作范本.当一个用户进程进行IO操作之前,它需要调用Open来指定并获取待操作文件或设备读取或写入的权限.一旦IO操作对象被打开,那么这个用户进程可以对这个…