首页 > 其他分享 >为什么 0.1 + 0.1 !== 0.2

为什么 0.1 + 0.1 !== 0.2

时间:2023-10-09 22:32:02浏览次数:38  
标签:为什么 函数 map 0.1 0.2 var 数组 parseInt


总结了几个很有意思的基础题目,分享一下。

为什么 0.1 + 0.1 !== 0.2

看到这个问题,不得不想到计算机中的数据类型,其中浮点数表示有限的精度。那么它就无法精确的表示所有的十进制小数,所以在在某些情况下,浮点数的运算可能会导致微小的精度误差。这就是为什么 0.1 + 0.1 不等于 0.2 的原因。

具体来说,0.10.2 这两个数字都无法在二进制浮点数表示中精确地表示为有限位数的小数。这导致了一个微小的误差,当它们相加时,这个误差会叠加,使得结果不等于 0.2

这个问题不仅适用于 JavaScript,还适用于大多数编程语言中使用浮点数表示的情况。为了处理这种情况,通常需要在比较浮点数时使用某种容忍误差的方法,而不是直接进行相等性比较。

在 JavaScript 中,可以使用以下方法来处理浮点数的比较:

// 使用小数点后的位数来比较
const num1 = 0.1 + 0.1;
const num2 = 0.2;
const tolerance = 0.000001; // 定义一个容忍误差

if (Math.abs(num1 - num2) < tolerance) {
  console.log("它们大致相等");
} else {
  console.log("它们不相等");
}

["1","2","3"].map(parseInt) 结果是什么

第一感觉是不是打印["1", "2", "3"]。不认真看确实会有这样的结论。实际上并不是。这个题目涉及到了map和parseIent两个知识点,首先了解一下这两个函数。

  1. map:JavaScript 中的 map() 函数是数组对象的一个高阶函数,它用于对数组的每个元素执行一个指定的函数,并返回一个新的数组,新数组中的元素是原始数组元素按照指定函数进行转换后的结果。map() 函数的基本语法如下:
array.map(callback(currentValue[, index[, array]])[, thisArg])
array.map(callback(currentValue[, index[, array]])[, thisArg])

参数说明:

  • callback:一个函数,用于对每个元素进行处理。这个函数接受三个参数:
  • currentValue:当前正在处理的数组元素。
  • index(可选):当前元素的索引。
  • array(可选):调用 map() 的数组本身。
  • thisArg(可选):可选参数,用于指定 callback 函数中 this 的值。

map() 函数的工作流程如下:

  • 从数组的第一个元素开始,依次对每个元素执行 callback 函数。
  • callback 函数的返回值存储在一个新数组中。
  • 返回新数组作为 map() 函数的结果。
  1. parseInt:函数接受两个参数:要解析的字符串和基数(进制)。但在 map 中,parseInt 被传递了三个参数:当前元素、当前索引和数组本身。

所以["1", "2", "3"].map(parseInt)的结果是[1, NaN, NaN]。

map 将按照以下方式调用 parseInt

  • 第一次调用:parseInt("1", 0, ["1", "2", "3"]),其中基数为 0(表示自动识别进制)。
  • 第二次调用:parseInt("2", 1, ["1", "2", "3"]),其中基数为 1。
  • 第三次调用:parseInt("3", 2, ["1", "2", "3"]),其中基数为 2。

parseInt 在解析字符串时,如果第一个字符无法转换为数字,则返回 NaN。在这里,第一次调用 parseInt 时,字符串 "1" 可以成功解析为数字 1。然而,在第二次和第三次调用时,基数参数不符合期望的进制,因此解析失败,返回 NaN

因此,["1", "2", "3"].map(parseInt) 的结果是 [1, NaN, NaN],这是由于 parseInt 函数在不同基数下的解析失败导致的。

下列题目输出结果

(function a () {
  "use strict";
  var a = b = 3;
})();
console.log("输出a" + (typeof a !== 'undefined'));
console.log("输出b" + (typeof b !== 'undefined'));

非严格模式下运行代码块 (function a (){ var a = b =3; })(); 包含了一个函数表达式。在这个代码块中,有以下操作:

  1. var a = b = 3;:这个语句声明了变量 a,但同时也声明了一个全局变量 b 并将其赋值为 3。在非严格模式下,未使用 varletconst 声明的变量会成为全局变量。
  2. console.log("输出a" + (typeof a !== 'undefined')):在这里,你尝试检查变量 a 是否被定义。由于 a 被声明为局部变量,因此在函数外部不可见,typeof a 返回 "undefined",因此整个表达式的结果是 "输出afalse"
  3. console.log("输出b" + (typeof b !== 'undefined')):这里尝试检查变量 b 是否被定义。虽然 b 在函数内部赋值,但由于没有使用 varletconst 来声明它,它成为了一个全局变量,因此在整个页面的作用域内都可见。typeof b 返回 "number"(因为它被赋值为 3),因此整个表达式的结果是 "输出btrue"。根据非严格模式下的变量作用域和声明方式,代码的输出结果是 "输出afalse""输出btrue"

严格模式下严格模式下不会输出任何结果,而会抛出错误。在上面代码块内,有一个立即执行函数 (function a (){ ... })();,它包含了以下行为:

  1. var a = b = 3;:在这行代码中,尝试声明一个局部变量 a,并将其赋值为 b。然而,这里存在一个陷阱。由于没有使用 varletconst 来声明 b,它成为了一个全局变量,而不是局部变量。这意味着 b 的作用域会泄漏到外部的函数作用域(全局作用域),而不是被限制在函数内部。
  2. 在严格模式下,var a 的作用域仅限于函数内部,所以 a 只能在函数内部访问,而在函数外部是不可见的。因此,尝试在函数外部访问 a 时会导致 Uncaught ReferenceError 错误。
  3. 同样,在严格模式下,尝试在函数外部访问全局变量 b 时,也会导致 Uncaught ReferenceError 错误,因为全局变量 b 在非严格模式下会被隐式地创建,但在严格模式下需要显式声明。

所以在定义**var a = b =3;**时就会抛出错误,不会执行打印的语句

为什么 0.1 + 0.1 !== 0.2_数组

标签:为什么,函数,map,0.1,0.2,var,数组,parseInt
From: https://blog.51cto.com/u_14196886/7782091

相关文章

  • 文心一言 VS 讯飞星火 VS chatgpt (109)-- 算法导论10.1 7题
    七、用go语言,说明如何用两个队列实现一个栈,并分析相关栈操作的运行时间。文心一言:在Go语言中,我们可以用两个队列(queue1和queue2)实现一个栈。以下是实现代码:packagemainimport"fmt"typeQueuestruct{items[]int}func(q*Queue)Enqueue(itemint......
  • 上周热点回顾(10.2-10.8)
    热点随笔:· 【故障公告】遭遇用心良苦的疯狂攻击:DDoS+CC攻击 (博客园团队)· 一种对数据库友好的GUID的变种使用方法 (ensleep)· BS系统的登录鉴权流程演变 (风吹草)· 会员权益-新功能发布:定时发布博文 (博客园团队)· 面试官随便问几个问题就知道你究竟做没做过微......
  • 算法训练day29 LeetCode 39.40.131
    算法训练day29LeetCode39.40.13139.组合总和题目39.组合总和-力扣(LeetCode)题解代码随想录(programmercarl.com)classSolution{private:vector<vector<int>>result;vector<int>path;voidbacktracking(vector<int>&candidates,......
  • 学习小结(10.2~10.8)
    “在还有未来的过去渴望着美好结局”——草东没有派对《山海》学习记录日期10.210.310.4内容考试考试考试收获又是dp、期望qwq李超线段树加急!!!T_T经典不会T3、T4,T2莫队还没对,T1构造错了反思T2DP没推出来合适的状态和方程T3又是期望制裁昨天刚准备......
  • 文心一言 VS 讯飞星火 VS chatgpt (108)-- 算法导论10.1 6题
    六、用go语言,说明如何用两个栈实现一个队列,并分析相关队列操作的运行时间。文心一言:使用两个栈实现队列的基本思想是利用一个栈(stack1)来处理入队操作,另一个栈(stack2)来处理出队操作。以下是使用Go语言实现的代码:packagemainimport"fmt"typeQueuestruct{s......
  • 文心一言 VS 讯飞星火 VS chatgpt (108)-- 算法导论10.1 6题
    六、用go语言,说明如何用两个栈实现一个队列,并分析相关队列操作的运行时间。文心一言:使用两个栈实现队列的基本思想是利用一个栈(stack1)来处理入队操作,另一个栈(stack2)来处理出队操作。以下是使用Go语言实现的代码:packagemainimport"fmt"typeQueuestruct{stack......
  • 为什么redis使用单线程——简单说下
    redis使用单线程主要原因第一个,每条命令都是原子操作,单线程能够保证原子性。第二个原因,如果设计为多线程,肯定存在锁的竞争导致锁的获取释放开销,线程切换的开销,这与我们使用redis是相违背的。尽管redis设计为单线程,但是他的性能很高,主要原因是基于内存,以及pipeline机制都能保证redi......
  • 文字组件里的表格为什么分到两页
    问题:完全可以显示在一页上的表格为什么会分成两页解决方法:选取整个表格》开始》段落》换行和分页》分页组中除孤行控制以外全部取消》确定......
  • 为什么荒原之梦网打不开了?荒原之梦网打不开怎么办?
    通常情况下,【荒原之梦考研数学网(zhaokaifeng.com)】在全国各地的打开速度都在0.2秒左右,这样的访问速度保证了大家的学习体验。但是,如果遇到荒原之梦网打不开,或者打开速度明显很慢的情况该怎么办呢?遇到这种情况,可以立即向荒原之梦网发送反馈邮件,我们将在第一时间内排查并给予答......
  • qt ui编辑器的按钮相应槽函数为什么没有connect连接
    Qt自动连接槽 AutomaticConnections其原理是由UIC在编译期自动生成连接信号槽的代码,仅限于.ui文件,如果是在.cpp中手写的ui还是要自己connect自动连接可以省去connect信号槽的那句,只需按照规则声明槽函数即可voidon_<objectname>_<signalname>(<signalparameters>);例如......