JavaScript中不纯函数的示例是什么

What is an example of an impure function in JavaScript

本文关键字:是什么 函数 JavaScript      更新时间:2023-09-26

看过很多纯函数以及它们如何没有副作用之后,不纯函数的例子是什么,它总是被当作不稳定和主要的误差来源?

例如,一个不纯的函数,它对自身范围之外的变量有副作用:

var count = 0;
function increaseCount(val) {
    count += val;
}

或者一个函数,它为同一输入返回不同的值,因为它计算的变量不是作为参数给出的:

var count = 0;
function getSomething() {
    return count > 0;
}

纯函数不依赖于也不修改其范围之外的变量的状态。

具体来说,这意味着纯函数总是在给定相同参数的情况下返回相同的结果。它的执行不依赖于系统的状态。

var values = { a: 1 };
function impureFunction ( items ) {
  var b = 1;
  items.a = items.a * b + 2;
  return items.a;
}
var c = impureFunction( values );
// Now `values.a` is 3, the impure function modifies it.

在这里,我们修改给定对象的属性。因此,我们修改了函数范围之外的对象:函数是不纯的。

var values = { a: 1 };
function pureFunction ( a ) {
  var b = 1;
  a = a * b + 2;
  return a;
}
var c = pureFunction( values.a );

我们只需修改函数范围内的参数,外部不会修改任何内容!

var values = { a: 1 };
var b = 1;
function impureFunction ( a ) {
  a = a * b + 2;
  return a;
}
var c = impureFunction( values.a );
// Actually, the value of `c` will depend on the value of `b`.
// In a bigger codebase, you may forget about that, which may 
// surprise you because the result can vary implicitly.

在这里,b 不在函数的范围内。结果将取决于上下文:预期的惊喜!

var values = { a: 1 };
var b = 1;
function pureFunction ( a, c ) {
  a = a * c + 2;
  return a;
}
var c = pureFunction( values.a, b );
// Here it's made clear that the value of `c` will depend on
// the value of `b`.

参考 : 更多详情,请点击这里

Math.random()是一个

不纯的函数;它更改Math对象的内部状态,因此您在连续调用时获得不同的值。 console.log()alert() 是不纯函数,因为它们具有副作用(尽管它们生成相同的行为并且对于相同的调用始终返回相同的值)。

任何更改其参数之一的内部状态或某些外部变量的值的函数都是不纯函数。这包括闭包,其中调用方法会更改闭包本身的内部状态:

let nextInt = (function() {
    var i = 0;
    return function() {
        return i++;
    };
})();
let a = nextInt(); // sets a to 0
let b = nextInt(); // sets b to 1
                   // etc.

你从哪里得到不纯函数总是被认为是一件坏事的想法?

  1. 不纯函子是一个返回不同结果的函数相同的输入参数,也就是说它取决于某种状态;
  2. 对于相同的输入参数,可能返回相同结果的函数,但 这会改变其他状态对象。对象它不依赖但其他人依赖//导致副作用

例:

1)

 var toggled = false; /* state */
    /*impure function*/
    function  impureFn(number){
     if(number%2 == 0)
      toggled = true;
     return toggled;
    }
    /*Execute this in order */
    impureFn(5) // returns false
    impureFn(2) //returns true
    impureFn(5) // now returns true

我能想到的一个例子(确实很令人困惑)是Array#reverse()。它不是返回一个新数组,而是在返回原始数组的同时就地修改它。

其他一些数组函数也这样做,例如splicepushshiftpopunshift

pure函数(获取参数并返回新值):

function (objectArgument) {
   return {
       value: objectArgument.value + 123,
       // other arguments
   };
}

impure函数(获取参数,修改它并返回修改的对象):

function (objectArgument) {
   objectArgument.value += 123;
   return objectArgument;
}