javadouble数组
A. java定义一个double类型长度为10的数组,从控制台输入10个小数依次为数组每一个元素赋值。
B. java中double类数组要怎样才能精确到有几位小数点
double的表示方式如下:
符号位(1位)
|
指数(11位,1位符号位+10位指数位)
|
尾数(52位)
存储方式是按照浮点的形式存储,所以不存在整数部分和小数部分。比如1678.3456
=
1.6783456
*
10^3,但计算机只认识0、1,所以要将其转化成二进制小数,我们不管转换后的结果如何,转换后得到的浮点数形式肯定是这种1.xxxxxx
*
2
^
y,其中xxxxxx表示小数部分,就是尾数,而小数点前面始终是1,可以不存储,y就是指数部分。
所以上面的1.xxxxxx
*
2^y在计算机中就表示为:
0
|
y
+
127
|
xxxxxx
最前面的符号位为0表示正;指数存储时要加上127;xxxxxx就是尾数。
float的表示方法类似,只是位数不一样,如下:
符号位(1位)
|
指数(8位)
|
尾数(23位)
C. Java生成一个double数组,数组的长度由main的参数确定
一、需求分析
1、main函数接收参数时使用String args[],按照顺序接收若干个参数,本题目中只需要接收1个
2、随机double数函数是Random类的nextDouble()方法
3、for和foreach在java里的写法都是for,不同之处在于foreach写法是用冒号隔开,而for是分号隔开
二、代码如下
import java.io.*;
import java.util.*;
public class Main
{
public static void main(String args[])
{
int len = Integer.parseInt(args[0]);
Double[] ds = new Double[len];
Random random = new Random();
for (int i=0; i<len; i++) {
ds[i] = random.nextDouble();
}
for(double d : ds)
{
System.out.println(d);
}
}
}
D. 如何定义JAVA中double类型的数组
如果您在一定区间内初始化别的数,可以使用Fill方法。
第一步:声明数组。
double[] arr=new double[50];
第二步:填充。(比如都初始化成3.14)
Arrays.Fill(arr,3.14)。
E. JAVA中double类型的数组怎么定义
如果您在一定区间内初始化别的数,可以使用Fill方法。
第一步:声明数组。
double[] arr=new double[50];
第二步:填充。(比如都初始化成3.14)
Arrays.Fill(arr,3.14);
F. java中double数组转化为byte数组
其实问题转换为double如何转换为byte数组,如果知道一个double如何转换为byte数组,其他不过是重复而已
先介绍double转byte[]的方法:
假如有一个double d = 503.2135013通过以下方法可以得到byte[]
[java]view plain
publicstaticbyte[]double2Bytes(doubled){
longvalue=Double.doubleToRawLongBits(d);
byte[]byteRet=newbyte[8];
for(inti=0;i<8;i++){
byteRet[i]=(byte)((value>>8*i)&0xff);
}
returnbyteRet;
}
- 得到的8个字节分别是:0x75 0xd2 0x56 0x80 0x6a 0x73 0x7f 0x40
- 下面就来介绍byte[]转double方法:
(byte[]arr){
longvalue=0;
for(inti=0;i<8;i++){
value|=((long)(arr[i]&0xff))<<(8*i);
}
returnDouble.longBitsToDouble(value);
}
- 把0x75 0xd2 0x56 0x80 0x6a 0x73 0x7f 0x40传入bytes2Double方法可以得到503.2135013
[java]view plain
G. java中Double与double型数组有啥区别
最大的区别是Double数组中可以有null值。
因为,Double是java对象,double是java原型数据类型。
所以,Double数组是一个对象数组,double型数组是一个原型数组。
从效率来看,double数组的效率会高。