草庐IT

numbers_float

全部标签

javascript - 期望一个 float 数组接近 Jasmine 中的另一个数组

我正在测试一个返回数字数组的Javascript函数,以查看返回的数组是否包含与包含预期输出的数组相同的元素:expect(myArray).toEqual(expectedArray);如果myArray和expectedArray仅包含整数,则此操作完美无缺,但如果存在至少一个float,则会因浮点精度错误而失败。toBeCloseTo似乎对数组不起作用。目前我正在循环进行成员检查:for(vari=0;i...但是有没有更简洁的方法来做到这一点?如果测试因任何原因失败,输出将包含大量骇人听闻的错误消息。 最佳答案 下面的代码应

javascript - 为什么 "(2.5 < 2.5 + Number.EPSILON)"在 JavaScript 中是假的?

我想在数组中查找小于某个值的值。我尝试使用Number.EPSILON,因为输入值不是确定值(例如1.5000000000001)。我在测试中发现了一些奇怪的东西:>>(1.5>(2.5这是为什么?测试环境为Chrome浏览器控制台。 最佳答案 同时Number.EPSILON本身可以精确表示,但这并不能保证向其添加值(或对其进行任何进一步操作)将导致完美的精度。在这种情况下,1.5+Number.EPSILON结果略高于1.5:console.log(1.5+Number.EPSILON);明显大于1.5。另一方面,将2.5添加到

javascript - 在 JavaScript 中实现 32 位 float 或 64 位长整型?

有谁知道准确实现IEEE754的JavaScript库?32位浮点值规范?我问是因为我正在尝试用JavaScript编写交叉编译器,并且由于源语言严格要求浮点值遵守IEEE754,因此生成的JavaScript代码也必须这样做。这意味着我必须能够为32位float的加法、减法、乘法和除法获得完全正确的IEEE754值。不幸的是,标准的JavaScriptNumber类型是64位double,它会给出与我预期不同的结果。该项目确实必须使用JavaScript,这是我尚未克服的唯一主要障碍。我也遇到了64位longs的问题。 最佳答案

javascript - Array.prototype.filter(Number) 中的 'Number' 是如何工作的?

我发现使用Array.prototype.filter方法从字符串中删除所有非数字的方式很酷,但我不完全确定它是如何使用Number实现这个的原型(prototype):vararr='75number9';arr.split(/[^\d]/).filter(Number);//returns[75,9]当我检查typeofNumber时,我返回'function'。这是怎么回事?让我更加困惑的是,如果我用String替换Number,结果是一样的。它仍然有效!arr.split(/[^\d]/).filter(String);//returns[75,9]Array和Object作为

javascript - 使用 JavaScript Number() 函数比较两个数字是否相等

当我尝试使用JavaScriptNumber()函数比较两个数字时,它会为相等的数字返回false值。但是,大于(">")和小于("true。varfn=20;varsn=20;alert(newNumber(fn)===newNumber(sn));此警报返回一个false值。为什么这不返回true? 最佳答案 newNumber()willreturnobjectnotNumberandyoucannotcompareobjectslikethis.alert({}==={});willreturnfalsetoo.删除new,

javascript - 什么是 Array.map(Function.call,Number)

vararray1=[1,4,9,16];map1=array1.map(Function.call,Number);为什么map1的输出是[0,1,2,3],这个map函数是干什么的? 最佳答案 Array.prototype.map调用为数组的每个成员提供的函数,并返回一个由它们的返回值组成的新数组。在这种情况下,提供的函数是Function.call.Array.prototype.map的第二个参数指定所提供的函数应该运行的上下文。在这种情况下,上下文是Number.Array.prototype.map的简单实现可能类似于

javascript - 参数类型 Number 不可分配给参数类型 String|Function

varstr=name.toUpperCase();varch=newArray();ch=str.split('');for(vari=0;i=97){varpos=i+1;result_code.replace(pos.toString()+pos.toString()+pos.toString()+pos.toString(),(temp-temp_integer)+40);}}}此代码在这一行result_code.replace(pos.toString()+pos.toString()+pos.toString()+pos.toString(),(temp-temp_int

javascript - javascript 中 isNaN 和 Number.isNaN 的混淆

我对NaN的工作原理感到困惑。我执行了isNaN(undefined)它返回了true。但是,如果我将使用Number.isNaN(undefined),它将返回false。那么我应该使用哪一个。还有为什么结果会有这么大的差异。 最佳答案 引用自ponyfooarticleonnumbersinES6:Number.isNaNisalmostidenticaltoES5globalisNaNmethod.Number.isNaNreturnswhethertheprovidedvalueequalsNaN.Thisisaverydi

javascript - 使用 Javascript 或 Jquery 将整数转换为精度为 2 的 float

我想将整数转换为精度为2的float。即。-11=>11.0045=>45.00请帮帮我。谢谢。 最佳答案 使用.toFixed:varnum=45;num.toFixed(2);//"45.00" 关于javascript-使用Javascript或Jquery将整数转换为精度为2的float,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/11685253/

C语言中float(浮点数)与二进制的转换关系

1、float浮点数在IEEE-754标准中float定义格式为:|------|------------|---------------------------------------||符号|--阶码—|------------尾数---------------------|符号表示正负:0为正,1为负;阶码表示基的指数,因为是二进制,因此基是2,表示为2^n,阶数需要转换时需要±127尾数表示小数点后面的数,需要由二进制转换成小数点后的数在实际的物理存储中又分为如下长度:s(符号)E(阶码)M(尾数)32bit1bit8bit23bit64bit1bit11bit52bit二进制转flo