floor:下退 Math.floor(12.9999) = 12 ceil:上进 Math.ceil(12.1) = 13round: 四舍五入 Math.round(12.5) = 13 Math.round(12.4) = 12
二、小数位数控制
保留到整数:exam = Math.round(exam)
保留一位小数:exam = Math.round(exam * 10) / 10
保留二位小数:exam = Math.round(exam * 100) / 100
保留三位小数:exam = Math.round(exam * 1000) /1000
其它依次类推。
1、打开eclipse创建一个Java工程项目。在src下创建类Main,创建后的工程目录如图。
2、先在Main类中加入main函数。
3、然后创建一个用科学计数法表示的变量 scienceNum。
4、接着先是把科学计数法表示的数转换成字符串,然后再通过BigDemical将字符串转换成正常的数字,最后将转换后的数字输出,具体代码如图。
5、通过java应用程序的方式运行Main.java,运行结果如图。
浮点数值的最高精度是17位小数,但在进行运算的时候其精确度却远远不如整数;整数在进行运算的时候都会转成10进制; 而java和JavaScript中计算小数运算时,都会先将十进制的小数换算到对应的二进制,一部分小数并不能完整的换算为二进制,这里就出现了第一次的误差。待小数都换算为二进制后,再进行二进制间的运算,得到二进制结果。然后再将二进制结果换算为十进制,这里通常会出现第二次的误差。
所以(0.1+0.2)!=03
解决这种问题,可以将小数变成整数进行运算,然后再将结果变为小数。
//乘法
function multiNum (a,b){
var c = 0,
d = a.toString(),
e = b.toString()
try {
c += d.split(".")[1].length
} catch (f) { }
try {
c += e.split(".")[1].length
} catch (f) { }
return Number(d.replace(".","")) * Number(e.replace(".","")) / Math.pow(10,c)
}
//除法
function divide (a,b){
var c,d,e = 0,
f = 0
try {
e = a.toString().split(".")[1].length
} catch (g) { }
try {
f = b.toString().split(".")[1].length
} catch (g) { }
return c = Number(a.toString().replace(".","")),d = Number(b.toString().replace(".","")),this.mul(c / d,Math.pow(10,f - e))
}
//加法
function addNum (a,b){
var c,d,e
try {
c = a.toString().split(".")[1].length
} catch (f) {
c = 0
}
try {
d = b.toString().split(".")[1].length
} catch (f) {
d = 0
}
return e = Math.pow(10,Math.max(c,d)),(multiNum(a,e) + multiNum(b,e)) / e
}
//减法
function subNum (a,b) {
var c,d,e
try {
c = a.toString().split(".")[1].length
} catch (f) {
c = 0
}
try {
d = b.toString().split(".")[1].length
} catch (f) {
d = 0
}
return e = Math.pow(10,Math.max(c,d)),(multiNum(a,e) - multiNum(b,e)) / e
}