返回顶部
首页 > 资讯 > 前端开发 > JavaScript >JavaScript数据类型对函数式编程的影响示例解析
  • 591
分享到

JavaScript数据类型对函数式编程的影响示例解析

JavaScript数据类型函数式编程JavaScript数据类型 2023-02-23 11:02:04 591人浏览 安东尼
摘要

目录前言javascript中 的数据类型中的可变数据原始类型(基本类型)对象类型(引用类型)JavaScript 为何能会让纯函数变得不纯?如何解决可变数据的影响?数据拷贝使用不可

前言

本篇文章是JavaScript 函数式编程 学习系列第二篇,感兴趣也可以先去看第一篇:

  • 一文理解JavaScript中的函数式编程的概念
  • JavaScript数据类型对函数式编程的影响
  • 不可变数据方案之immer.js实现探索

前文 一文理解JavaScript中的函数式编程的概念 中写了函数式编程的概念,本篇文章继上文之后,来梳理 JavaScript 数据类型对函数式编程的影响。

函数式编程编程的核心就是 纯函数 和隔离 副作用 ,为了让 纯函数 保持纯粹,纯函数的参数或者内部引用的外部数据应该是不可变数据。但 JavaScript 中的数据类型并不是都是不可变的,而数据类型的可变性,很有可能让 纯函数 变的不纯。

因此,本篇文章的目的有两点:

  • 探索 JavaScript 的数据类型来了解的可变数据的根源。
  • JavaScript 的可变数据数据是怎么让 纯函数 变得不纯的?
  • 如何解决 可变数据 的影响?

JavaScript中 的数据类型中的可变数据

在 JavaScript 中,数据类型有以下 8 种:

  • null
  • undefined
  • boolean
  • number
  • symbol -- 在 es6 中被加入
  • bigint -- es6+ 被加入
  • object

注意点:

在 JavaScript 中,变量是没有类型的,值才有类型。变量可以在任何时候,持有任何值。

原始类型(基本类型)

上面 8 中类型除了 object ,其他都是原始类型,原始类型存储的都是值,其特点有两点:

  • 没有方法可以直接调用
  • 原始类型的数据是不可被改变的,改变一个变量的值,并不是把值改变了,而是让变量拥有新的值。

注意点:

  • '1'.toString()或者false.toString()等可以用的原因是被强制转换成了 String 类型也就是对象类型,所以可以调用 toString 函数。
  • 对于null来说,很多人会认为它是个对象类型,其实是错误的。typeof null 会输出 object,这只是 JS 存在的一个悠久 Bug,而且好像永远不会也不会被修复,因为有太多已经存在的 WEB 的内容依存着这个 bug。注: 在 JS 的最初版本中使用的是 32 位系统,为了性能考虑使用低位存储变量的类型信息,000开头代表是对象,然而 null 表示为全零,所以将它错误的判断为 object 。虽然现在的内部类型判断代码已经改变了,但是对于这个 Bug 却是一直流传下来。

对象类型(引用类型)

而除了原始类型,剩下的 object 就是对象类型,和原始类型的不同点在于:原始类型存储的是值,对象类型存储的是地址。

经典示例:

var c = 1;
var d = c;
d = 2;
console.log(c === d) // false
var a = {
    name: "张三",
    age: 20
}
var b = a;
b.age = 21;
console.log(a.age === b.age) // true

示例中把变量 a 的值给到了变量 b , b 修改了age 属性,但是 a 的 age 属性也跟着变了,是因为 var b = a 是 a 把对象的引用地址赋值给 b ,这时候 a 和 b 指向的是内存中的同一个数据。

而 c 给 d 的是值,并不是一个引用,相当于复制了一份数据。

因此可以知道原型类型的数据是不可变的,而对象类型的数据是可变的。

JavaScript 为何能会让纯函数变得不纯?

JavaScript 中的对象类型的数据是可变,而可变性,就代表了不确定性,纯函数 中使用了不确性的数据就会导致不纯,因为其违背了 纯函数 的特征:不受外界影响,不影响外界。

下面来看一个例子:

A 同学写了这么一段代码,初始化生成了一个 “zhangsan” 用户。

export const defaultUserInfo = {
    name: "名称",
    age: 20,
    hobby: ["玩耍"]
};
export function initUser(userTemplate, name, age) {
    const newUser = userTemplate;
    newUser.name = name;
    newUser.age = age;
    return newUser;
}
const zhangsan = userInit(userDefaultInfo, "zhangsan", 21);

然后 B 同学在开发其他页面的时候,看到有初始化用户信息的方法,然后直接复制过去,初始化了一个 “lisi” 用户。

import { defaultUserInfo, initUser } from "xxx模块"。
const lisi = userInit(userDefaultInfo, "lisi", 21);

检测的时候看到自己初始化的用户信息正确的就没有去检查之前 A 同学的是否是正确的,上线后发现所有的用户都变成了 lisi 。因为 userDefaultInfo 是一个引用类型,userInit(userDefaultInfo, "xxx", xx) 操作的都是内存中的同一个对象。其原因就是因为 A 和 B 开发者犯了一个错误,把可变数据传递到了 userInit 函数内部进行处理,哪怕进行了浅层拷贝,也出现了问题。究其原因还是因为给函数传递进去了一个 可变数据。

我们校验一个 纯函数 有效性的关键依据,永远是“针对已知的输入,能否给出符合预期的输出”,而上面例子中 initUser 函数没有违背这个规则,但是在可变数据的影响下,让它产生了 副作用,对外界已有的数据造成了影响。

如何解决可变数据的影响?

数据拷贝

从使用函数方的角度来看,既然造成这个问题的原因是因为传递进去的数据是 可变数据 ,那么我就复制一份数据传递给函数内部使用,随便你怎么修改,都不会影响外界其他数据。

比如我们使用前面例子中的 initUser 函数时,先拷贝一份数据:

function copyFunc(object) {
    return JSON.parse(JSON.string(object));
}
const zhangsan = userInit(copyFunc(userDefaultInfo), "zhangsan", 21);
const lisi = userInit(copyFunc(userDefaultInfo), "lisi", 21);
console.log(zhangsan.name === lisi.name); // false

进行拷贝后的数据传递给 userInit 函数,就不会出现问题了。这里的 copyFunc 只能针对部分数据类型,对不少类型是不支持的,具体可以去看一下 关于JSON.parse(JSON.stringify(obj))实现深拷贝应该注意的坑 这篇文章。

从被调用函数方来看,在使用 object 类型数据时,函数内部尽量不要去修改外界 object 数据(通过参数传递,或者直接使用外界的对象都不建议去修改),修改之前可以拷贝一份再修改。

比如:

export function initUser(userTemplate, name, age) {
    const newUser = copyFunc(userTemplate);
    newUser.name = name;
    newUser.age = age;
    return newUser;
}

使用不可变数据方案

拷贝的数据比较大的时候,会出现性能问题,因此出现了不可变数据的方案。

现在不可变数据常见的有两种: Immutable.js 和 immer.js 。它们都能实现在操作数据后,返回新的一个数据,而不影响之前的数据。

Immutable.js 实现了持久化数据结构,实现原理说明(引用于immutable.js 和 immer):

  • 使用旧数据创建新数据时,要保证旧数据同时可用且不变。同时为了避免 deepCopy 把所有节点都复制一遍带来的性能问题,immutable 使用了结构共享方式,即如果对象树中的一个节点改变,只修改这个节点和受它影响的父节点,其他节点共享。
  • immutable-js 使用了另一套数据结构 api,它会将原生数据类型都转化为 immutable-js 内部对象。

因此 Immutable.js 需要严格使用它自定义的操作数据的方法才行。

immer.js 利用了 es6 的 Proxy 来进行对数据操作的拦截实现,具体原理可去 剖析 Immer.js 工作原理与设计模式 这里看看,也可以去网上查询。

总结

  • 分析 JavaScript中 的数据类型中的可变数据根源:Object 数据结构。
  • 探索了其可变数据数据是怎么对 纯函数 造成的影响:Object 数据的不确定性。
  • 分析了如何解决 可变数据 的影响:深拷贝 和使用 不可变数据结构.

参考:

  • JavaScript 函数式编程实践指南
  • immutable.js 和 immer)

以上就是JavaScript数据类型对函数式编程的影响示例解析的详细内容,更多关于JavaScript数据类型函数式编程的资料请关注编程网其它相关文章!

--结束END--

本文标题: JavaScript数据类型对函数式编程的影响示例解析

本文链接: https://lsjlt.com/news/197214.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • JavaScript数据类型对函数式编程的影响示例解析
    目录前言JavaScript中 的数据类型中的可变数据原始类型(基本类型)对象类型(引用类型)JavaScript 为何能会让纯函数变得不纯?如何解决可变数据的影响?数据拷贝使用不可...
    99+
    2023-02-23
    JavaScript数据类型函数式编程 JavaScript 数据类型
  • JavaScript数据类型对函数式编程的影响是什么
    这篇文章主要介绍了JavaScript数据类型对函数式编程的影响是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇JavaScript数据类型对函数式编程的影响是什么文章都会有所收获,下面我们一起来看看吧。J...
    99+
    2023-07-05
  • JavaScript函数式编程示例分析
    目录函数式编程函数柯理化(Curring)Compose场景案例总结函数式编程 1.函数式编程指的是函数的映射关系 2.vue3、react16.8的函数组件推动了前端函数编程 3....
    99+
    2022-11-13
    JavaScript函数式编程 JS函数式编程
  • JavaScript函数式编程的示例分析
    这篇文章给大家分享的是有关JavaScript函数式编程的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。看过许多关于函数式编程的讲解,但是其中大部分是停留在理论层面,还有...
    99+
    2024-04-02
  • Python的数据类型对异步编程有何影响?
    在现代软件开发中,异步编程已经成为了一种主流的编程方式。Python作为一种高级编程语言,也支持异步编程。在Python的异步编程中,数据类型对代码的性能和效率都有着重要的影响。 Python中常用的数据类型有列表、元组、字典和集合等。在...
    99+
    2023-08-15
    数据类型 异步编程 二维码
  • JavaScript中数据类型的变化对ASP异步编程有影响吗?
    随着JavaScript的不断发展,数据类型的变化也越来越明显。而在ASP异步编程中,这些数据类型的变化是否会对程序产生影响呢?本文将对这一问题进行深入探讨,并结合演示代码来说明。 JavaScript中的数据类型 首先,我们需要了解Ja...
    99+
    2023-11-02
    异步编程 javascript 数据类型
  • 数据类型对 ASP 程序性能的影响分析
    ASP(Active Server Pages)是一种基于服务器端的动态网页技术,它使用VBScript或JScript等脚本语言来创建动态内容。在ASP程序中,数据类型的选择对程序的性能有着重要的影响。本文将对数据类型对ASP程序性能的影...
    99+
    2023-11-12
    并发 数据类型 编程算法
  • Python中的数据类型是否对Bash编程有影响?
    Python和Bash是两种不同的编程语言,它们有着不同的数据类型和语法规则。因此,Python中的数据类型是否对Bash编程有影响呢?本文将探讨这个问题。 首先,我们需要了解Python和Bash中常见的数据类型。Python中的常见数据...
    99+
    2023-10-26
    数据类型 bash 编程算法
  • javascript数据类型的示例分析
    这篇文章将为大家详细讲解有关javascript数据类型的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1. undefined 和 nullundefined是...
    99+
    2024-04-02
  • Java中响应式编程如何影响索引数据类型?
    Java作为一门强大的编程语言,一直在不断的发展和创新,其中响应式编程是一种非常流行的编程范式。随着响应式编程的不断发展,它对Java中的索引数据类型也产生了一些影响。本文将详细介绍Java中响应式编程如何影响索引数据类型,并通过演示代码...
    99+
    2023-09-09
    响应 索引 数据类型
  • 函数式编程对golang有什么影响?
    函数式编程在 go 中的使用显着提高了代码的可维护性、并发性和可测试性。它强调使用不可变数据和函数,并通过一等函数、闭包和 goroutine 等特性在 go 中实现。函数式编程原则包括...
    99+
    2024-05-02
    golang 函数式编程 作用域
  • GO编程中的数据类型选择对性能的影响
    在GO编程中,数据类型的选择对代码性能有着重要的影响。在本文中,我们将探讨GO语言中一些常见的数据类型,以及它们对代码性能的影响。 布尔类型 布尔类型是GO语言中最简单的数据类型之一,只有两个值:true和false。在代码中使用布尔...
    99+
    2023-09-20
    关键字 数据类型 编程算法
  • JavaScript中数据类型的示例分析
    这篇文章主要介绍JavaScript中数据类型的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!一,数据类型以下内容基于ES5(ES6引入了一种新的原始数据类型Symbol,表...
    99+
    2024-04-02
  • 了解 ASP 数据类型对 Apache 同步的影响。
    ASP(Active Server Pages)是一种基于服务器端脚本的Web开发技术。它可以在Web服务器上执行脚本,生成动态的Web页面。在ASP中,数据类型是非常重要的,因为不同的数据类型对于Apache的同步影响也不同。 在ASP中...
    99+
    2023-08-31
    数据类型 apache 同步
  • JavaScript数据类型转换的示例分析
    这篇文章主要介绍JavaScript数据类型转换的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!JS数据类型在 JavaScript 语言中数据类型分为2大类:基本数据类型和复杂数据类型基本数据类型有:num...
    99+
    2023-06-15
  • python函数式编程的示例分析
    这篇文章给大家分享的是有关python函数式编程的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。python可以做什么Python是一种编程语言,内置了许多有效的工具,Python几乎无所不能,该语言通俗...
    99+
    2023-06-14
  • JavaScript中变量、数据类型的示例分析
    小编给大家分享一下JavaScript中变量、数据类型的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1 如何声明变量变...
    99+
    2024-04-02
  • JavaScript基础之数据类型的示例分析
    这篇文章主要为大家展示了“JavaScript基础之数据类型的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“JavaScript基础之数据类型的示例分析...
    99+
    2024-04-02
  • JavaScript中的函数式编程实例分析
    这篇文章主要介绍“JavaScript中的函数式编程实例分析”,在日常操作中,相信很多人在JavaScript中的函数式编程实例分析问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”JavaScript中的函数式...
    99+
    2023-07-05
  • Golang泛型编程对参数传递的影响
    go 1.18 中的泛型编程引入以下参数传递变化:类型推断:编译器自动推断泛型函数和类型参数,无需手动指定。值语义:泛型函数对值进行操作,不会修改原始变量。通用代码重用:泛型编程允许创建...
    99+
    2024-04-13
    golang 泛型编程
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作