javascript随机数发现的一个parseInt函数的问题
前几天想伪造一些数据,用到了随机数,没有自己写,便在网上找了一下,找到了这篇文章:https://www.cnblogs.com/starof/p/4988516.html 。之后测试了一下,发现了一个关于parseInt的问题。最后发现造成问题的原因是对该方法不够了解,下面详细说一下具体的过程。
上文中连接中的随机数方法是这样的(并添加一些测试代码):

var temp=randomNum(0,0); 这样调用链接中的方法,按照方法中的逻辑应该永远返回0才对,为什么还包含其他的数字……下面是一步一步的测试。
一、我先修改了一下上面的方法,我想要的效果是可以传入0-2个参数,并且参数大小不分先后:
// 获取随机数测试1
var getRangeRandomNumberTest1 = function(num1,num2){
num1 = num1 === undefined ? 0: num1;
num2 = num2 === undefined ? 0: num2;
var minNum=Math.min(num1,num2),maxNum=Math.max(num1,num2);
return parseInt(Math.random()*(maxNum-minNum+1)+minNum,10);
};
var tempRandomNumbers1=[];
for(var i=0;i<=100000000;i++){
var temp=getRangeRandomNumberTest1();
if(tempRandomNumbers1.indexOf(temp)<0){
tempRandomNumbers1.push(temp);
}
}
console.log("随机数数组长度:"+tempRandomNumbers1.length);
console.log("随机数数组内容:"+JSON.stringify(tempRandomNumbers1));
看一下测试结果:

这次结果没有什么意外,和上面的一样。
二、我想看一下,用这种方式调用,什么条件下返回结果不为0,下面是测试2:
// 获取随机数测试2
var getRangeRandomNumberTest2 = function(num1,num2){
num1 = num1 === undefined ? 0: num1;
num2 = num2 === undefined ? 0: num2;
var minNum=Math.min(num1,num2),maxNum=Math.max(num1,num2);
var temp1=Math.random();
var temp2=parseInt(temp1*(maxNum-minNum+1)+minNum,10);
var temp3="最大值:"+maxNum+";最小值:"+minNum+";随机数:"+temp1;
if(temp2!==0){
console.log(temp3);
}
return temp2;
}; var tempRandomNumbers2=[];
for(var i=0;i<=100000000;i++){
var temp=getRangeRandomNumberTest2();
if(tempRandomNumbers2.indexOf(temp)<0){
tempRandomNumbers2.push(temp);
}
}
console.log("随机数数组长度:"+tempRandomNumbers2.length);
console.log("随机数数组内容:"+JSON.stringify(tempRandomNumbers2));
同样再看一下测试结果:

console.log(parseInt(6.467984137170646e-7)); //上面生成的一个随机数 //输出结果:6
这里发现了一些问题,返回结果不为0的时候,生成的随机数都特别小;之后查了一下parseInt函数的定义和语法
//定义
parseInt() 函数可解析一个字符串,并返回一个整数。
//语法
parseInt(string, radix)
parseInt函数的第一个参数是字符串,那执行parseInt(6.467984137170646e-7)的过程应该是先将6.467984137170646e-7转成一个字符串
6.467984137170646e-7.toString() //输出结果:"6.467984137170646e-7"
0.0000006467984137170646.toString() //输出结果:"6.467984137170646e-7"
6.467984137170646e-7===0.0000006467984137170646 //输出结果:true
这时结果就要浮出水面了。在数字中6.467984137170646e-7,"e"有特定的含义。但是"6.467984137170646e-7"就是一个字符串,其中"e"没有什么特殊含义,不能表示10的几次幂,和其他的字符没有什么区别。
parseInt("0.0000006467984137170646") //输出结果:0 //这个结果是我们想要的结果
看到结果,现在问题应该是0.0000006467984137170646转为字符串的问题了
0.00000654321.toString() //输出结果:"0.00000654321"
0.000000654321.toString() //输出结果:"6.54321e-7"
0.0000000654321.toString() //输出结果:"6.54321e-8"

问题就在这里,Math.random()生成的随机数特别小时(小数点后面有连续的>=6个0时),这个小数会用科学计数法表示……
既然这样调用有问题(虽然是非常规调用),我想在换一种方式获取随机数。
三、下一种获取随机数的方法:
// 获取随机数测试3
var getRangeRandomNumberTest3 = function(num1,num2){
num1 = num1 === undefined ? 0: num1;
num2 = num2 === undefined ? 0: num2;
var minNum=Math.min(num1,num2),maxNum=Math.max(num1,num2);
return Math.floor(Math.random() * (maxNum - minNum)) + minNum;
};
var tempRandomNumbers3=[];
for(var i=0;i<=10000;i++){
var temp=getRangeRandomNumberTest3(9);
if(tempRandomNumbers3.indexOf(temp)<0){
tempRandomNumbers3.push(temp);
}
}
console.log("随机数数组长度:"+tempRandomNumbers3.length);
console.log("随机数数组内容:"+JSON.stringify(tempRandomNumbers3));
看一下测试结果:

这次测试,getRangeRandomNumberTest3(9),是这样调用的,本意想生成0-9的随机数,这里缺少了9,应该是Math.floor的问题,那就在换一个……
四、再换一种获取随机数的方法:
// 获取随机数测试4
var getRangeRandomNumberTest4 = function(num1,num2){
num1 = num1 === undefined ? 0: num1;
num2 = num2 === undefined ? 0: num2;
var minNum=Math.min(num1,num2),maxNum=Math.max(num1,num2);
return Math.round(Math.random() * (maxNum - minNum)) + minNum;
};
var tempRandomNumbers4=[];
for(var i=0;i<=100000000;i++){
var temp=getRangeRandomNumberTest4(9);
if(tempRandomNumbers4.indexOf(temp)<0){
tempRandomNumbers4.push(temp);
}
}
console.log("随机数数组长度:"+tempRandomNumbers4.length);
console.log("随机数数组内容:"+JSON.stringify(tempRandomNumbers4));
再看一下测试结果:

这次结果很是满意,达到了想要的结果……作为最终版,再将方法完善一下:
var getRangeRandomNumber = function(num1,num2){
num1 = Number.isInteger(num1) ? num1: 0;
num2 = Number.isInteger(num2) ? num2: 0;
var minNum=Math.min(num1,num2),maxNum=Math.max(num1,num2);
return Math.round(Math.random() * (maxNum - minNum)) + minNum;
};
下面看一下最终版的测试截图:

至此,这篇笔记就结束了,谢谢大家!
javascript随机数发现的一个parseInt函数的问题的更多相关文章
- Javascript 随机数函数 学习之二:产生服从正态分布随机数
一.为什么需要服从正态分布的随机函数 一般我们经常使用的随机数函数 Math.random() 产生的是服从均匀分布的随机数,能够模拟等概率出现的情况,例如 扔一个骰子,1到6点的概率应该相等,但现实 ...
- javascript使用parseInt函数时需要注意的一些问题
这个问题大家可能会忽视,我在项目中就遇到了.写了提醒一下大家!!! 在用javascript的parseInt函数时,parseInt("08")或者parseInt(" ...
- 字串符相关 split() 字串符分隔 substring() 提取字符串 substr()提取指定数目的字符 parseInt() 函数可解析一个字符串,并返回一个整数。
split() 方法将字符串分割为字符串数组,并返回此数组. stringObject.split(separator,limit) 我们将按照不同的方式来分割字符串: 使用指定符号分割字符串,代码如 ...
- Javascript 随机数函数 学习之一:产生服从均匀分布随机数
大家都知道Math.random是 javascript 中返回伪随机数的函数,但查看 MDN, The Math.random() function returns a floating-point ...
- 给你一个能生成1到5随机数的函数,用它写一个函数生成1到7的随机数。 (即,使用函数rand5()来实现函数rand7())
给你一个能生成1到5随机数的函数,用它写一个函数生成1到7的随机数. (即,使用函数rand5()来实现函数rand7()). 解答 rand5可以随机生成1,2,3,4,5:rand7可以随机生成1 ...
- JavaScript的parseint()函数
定义和用法 parseInt() 函数可解析一个字符串,并返回一个整数. 语法 parseInt(string, radix) 参数 描述 string 必选项.要转换为数字的字符串. radix 可 ...
- JavaScript parseInt() 函数
定义和用法 parseInt() 函数可解析一个字符串,并返回一个整数. 语法 parseInt(string, radix) 参数 描述 string 必需.要被解析的字符串. radix 可选.表 ...
- 在javascript中:(函数()()是一个匿名函数
在javascript中:(函数()()是一个匿名函数,它主要使用函数中的变量范围来避免全局变量,影响整个页面环境,并提高代码兼容性. (函数())是标准函数定义,但不会复制到任何变量.所以有一个没有 ...
- JS函数 编程练习 使用javascript代码写出一个函数:实现传入两个整数后弹出较大的整数。
编程练习 使用javascript代码写出一个函数:实现传入两个整数后弹出较大的整数. 任务 第一步: 编写代码完成一个函数的定义吧. 第二步: 我们来补充函数体中的控制语句,完成函数功能吧. 提示: ...
随机推荐
- ESP8266调试(UDP调试)
1.设置STA模式 AT+CWMODE=1 2.加入热点 AT+CWJAP="Admin_name","password" 3.开启单路连接 AT+CIPMUX ...
- ubuntu文件权限
以root身份登录linux. 在某一目录下执行 ls -al,显示类似如下内容: dr-xr-x---. 14 root root 4096 Aug 27 09:38 . dr-xr-xr-x. 2 ...
- 小白学 Python 爬虫(19):Xpath 基操
人生苦短,我用 Python 前文传送门: 小白学 Python 爬虫(1):开篇 小白学 Python 爬虫(2):前置准备(一)基本类库的安装 小白学 Python 爬虫(3):前置准备(二)Li ...
- 【MobX】391- MobX 入门教程(下)
点击上方"前端自习课"关注,学习起来~ 三.MobX 常用 API 介绍 3. 修改可观察数据 在上一部分内容中,我们了解到,对可观察的数据做出反应的时候,需要我们手动修改可观察数 ...
- 【重温基础】15.JS对象介绍
从这篇文章开始,复习 MDN 中级教程 的内容了,在初级教程中,我和大家分享了一些比较简单基础的知识点,并放在我的 [Cute-JavaScript]系列文章中. 关于[Cute-JavaScript ...
- 【IntelliJ Idea】使用学习
[IntelliJ Idea]使用学习 转载:https://www.cnblogs.com/yangchongxing/p/10658259.html 目录 ==================== ...
- 什么是cookie?什么是session?session和cookie有什么区别?
在技术面试中,经常被问到“说说Cookie和Session的区别”,大家都知道,Session是存储在服务器端的,Cookie是存储在客户端的,然而如果让你更详细地说明,你能说出几点?今天个推君就和大 ...
- 《Java基础知识》Java注解"@"详解
Java注解含义: Java注解,顾名思义,注解,就是对某一事物进行添加注释说明,会存放一些信息,这些信息可能对以后某个时段来说是很有用处的.Java注解又叫java标注,java提供了一套机制,使得 ...
- Python批量更新模块的方法【面试必学】
前言 本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理.作者:ranchlin 小编的环境为win10+python 3. ...
- Python基础-day01-8
变量的基本使用 程序就是用来处理数据的,而变量就是用来存储数据的 目标 变量定义 变量的类型 变量的命名 01. 变量定义 在 Python 中,每个变量 在使用前都必须赋值,变量 赋值以后 该变量 ...