❶ 八個byte中存儲的數據 如何變成一double呢java實現
不太清楚扒差8個Byte的存春團皮放方式或或,其實可以使用
Double.valueOf(new
String(B))
其中B是8個Byte的數組
❷ Java中給byte變數直接賦值可以自動轉換,但為什麼把int變數賦給byte變數需要強制轉換,同樣是int。
是這樣的,整型直接量在沒有加後綴的時候默認為int,但是當它被賦值給某個變數(這個變數是short型,int型,byte型中的一種)時,則會自動磨搏皮轉化成相對應的類型。
比如說byte a=127;這里的127在沒有賦值給a時默認是int型瞎差,賦值時自動調為byte型,並賦給a。
但是,如果出現這樣的情銀耐況:
int a=12;//此處a已經確定是int型
byte b=(byte)a;/**此處必須強制轉
換!因為a已經確
定是int型,必
須轉化成byte型
**/
❸ Java 讀取二進制文件 ,讀八個位元組,然後轉換成一個double,怎麼寫 我知道怎麼讀四個位元組轉成int的。
先申明一下你的前提是二進制文件,讀取8個位元組,那培埋么可以這么做:
public double readDouble(InputStream in) throws IOException {
byte[] tmp = new byte[8 * 8];//8個位元組蔽中歲長度宏睜
if (in != null && (in.read(tmp) != -1)) {
String str = new String(tmp);
return Double.valueOf(str);
}
return -1;
}
❹ Java:byte轉換為整型,是如何補位的呢
你好:試試下面的方法
public static void main(String args[]){
String s = "101011110001";
int x = 0;
for(char c: s.toCharArray())
x = x * 2 + (c == '1' ? 1 : 0);
System.out.println(x);
}
❺ java如何將位元組數組每8個轉換成double大致代碼就行 解決馬上給分
不給代碼,講下大致思路。
在java里,是用IEEE754標准來定義float,double這種浮點數的。
你可以先查下什麼是IEEE754標准,以及它是如何通過指數和尾數的方式來表示浮點數的。
然後在java里,double類型的長度是64位,也就是剛好8個byte的長度,通過IEEE754表示的話,類似於下面這樣的:
符號位 指數位 尾數位 指數偏移量
32位 1[31] 8[23-30] 23[0-22] 127
64位 1[63] 11[52-62] 52[0-51] 1023
所以,你只要把每個byte表示成二進制後拼成64位的二進制數,然後根據上面的公式來算出對應double類型的值就可以了。
❻ java中如何把一個String類型的變數轉換成double型的
Double.parseDouble(String類型變數)
例如定義String變數A為「10」,將String轉化為Double變數。
我寫出來了,你可以看一下,如下圖:
(6)javabytetodouble擴展閱讀:
Javascript具有的數據類型。
有5種基本數據類型:number(整形和浮點型)、string、null、boolean和undefined。此外還有一種復雜的數據類型—Object,Object本質上是由一組無序的名值對象組成的,如Date對象是一個日期和時間類型。
String對象是動態對象,需要創建對象實例後才能引用它的屬性和方法。在創建一個String對象變數時,可以使用new運算符來創建,也可以直接將字元串賦給變數。例如:strValue="Hello"與strVal=new String("hello")是等價的。
double(雙精度浮點型)是計算機使用的一種資料型別。比起單精度浮點數(float),double(雙精度浮點數)使用 64 位(8位元組) 來儲存一個浮點數。
它可以表示十進制的15或16位有效數字,負值取值范圍為 -1.7976E+308 到 -4.94065645841246544E-324,正值取值范圍為 4.94065645841246544E-324 到 1.797693E+308
❼ java如何將 byte [4] 轉換到float
推薦答案是錯誤地把位元組等同與字元。
byte b[]={0x41,(byte) 0xc8,0,0};
//方法1 流輸入,適用於ME/SE環境
//默認大端數,如果小端數,可以先翻轉數組
DataInputStream dis=new DataInputStream(new ByteArrayInputStream(b));
float f=dis.readFloat();
dis.close();
System.out.println(f);
//方法2 緩存輸入,適用於SE/EE環境
ByteBuffer buf=ByteBuffer.allocateDirect(4); //無額外內存的直接緩存
//buf=buf.order(ByteOrder.LITTLE_ENDIAN);//默認大端,小端用這行
buf.put(b);
buf.rewind();
float f2=buf.getFloat();
System.out.println(f2);
都將顯示讀出來的浮點數25.0
❽ java 中byte.short,int,long,float,double 的取值范圍分別是多少
其中byte、short、int、long都是表示整數的,只不過他們的取值范圍不一樣
byte的取值范圍為-128~127,佔用1個位元組(-2的7次方到2的7次方-1)
short的取值范圍為-32768~32767,佔用2個位元組(-2的15次方到2的15次方-1)
int的取值范圍為(-2147483648~2147483647),佔用4個位元組(-2的31次方到2的31次方-1)
long的取值范圍為(-9223372036854774808~9223372036854774807),佔用8個位元組(-2的63次方到2的63次方-1)
float和double是表示浮點型的數據類型,他們之間的區別在於他們的精確度不同
float 3.402823e+38 ~ 1.401298e-45(e+38表示是乘以10的38次方,同樣,e-45表示乘以10的負45次方)佔用4個位元組
double 1.797693e+308~ 4.9000000e-324 佔用8個位元組
double型比float型存儲范圍更大,精度更高,所以通常的浮點型的數據在不聲明的情況下都是double型的,如果要表示一個數據是float型的,可以在數據後面加上「F」。
浮點型的數據是不能完全精確的,所以有的時候在計算的時候可能會在小數點最後幾位出現浮動,這是正常的。
❾ java byte[]轉double,二進制值相同,輸出有差異
計算機中存儲數據是二進制的,就像十進制無法准確表示1/3一樣,二進制是無法准確表示1/10的,我覺得這是出現小數點的主要原因
❿ byte數組怎麼轉化為double
其實問題轉友仔神換為double如何轉換為byte數組,如果知道一個double如何轉換為byte數組,其他不過是重復而已 先介紹double轉byte[]的方法: 假如有一個double d = 503.2135013通過以戚首下方法可好虧以得到byte[] [java] view plain public static byte[...