❶ java中 int和float哪個精度高
int是整型,float是小數類型的,如果談精度的話肯定是float啦,因為如果一個小數類型的到int中也把小數點後的自動去掉了
❷ java 中int ,double的不同int能否操作小數呢咋么操作
類型不同,不能操作小數。
❸ JAVA 中除法後小數精度問題
你說的這個問題涉及到數字精度問題,在程序中,數字運算總是低精度的向高精度的自動轉化。比如(int)/(float)就會得到你想要的小數數位,這是由數字在計算機中的運算方式決定的。如果你用3/5.0或者3.0/5,你就可以得到你想要的小數。
在計算機中,整型(int)和浮點(float,double)的表示形式各不相同,佔用內存空間也不同,在運算時,為了得到正確的結果,就要進行對位,如果數據類型不一致,就要進行轉化。在硬體層面上就是把佔用內存少的整型向浮點轉換,也就是為這個整型添加額外的位元組參與運算,盡管這些位元組中都是0,這是數字精度的問題。
現在是兩個整形數,運算時,計算機認為不需要進行數據類型的轉化,所以就得到你見到的結果。
❹ java中,強制轉換符把float轉換為int時,按四捨五入,還是直接丟掉小數部分
直接舍掉小數 比如float是4.7 轉換成int 後是4 而不是5 要四捨五入的話轉換前先加上0.5
比如 int i ; double j = 4.7; i = (int)(j+0.5);
❺ java中int跟float的運算結果是float類型還是double類型
向參與運算的操作數的類型中的最高精度轉型,所以答案是float類型。如果有小數參與運算,則為double類型,因為java默認小數直接量是double類型的。如:
int n=100;
float f=1.1f;
則n+f的結果是float類型的,而6.0+n+f的結果是double類型的。
❻ java判斷數字類型(小數和整數)
java判斷數字類型是否為小數,可以採用正則表達式的方式來判斷,以下是使用正則表達式來判斷數字類型是否為小數的代碼:
public static boolean isNumber(String str) {
boolean isInt = Pattern.compile("^-?[1-9]\d*$").matcher(str).find();
boolean isDouble = Pattern.compile("^-?([1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0+|0)$").matcher(str).find();
return isInt || isDouble;
}
java判斷數字類型,正則表達式用法:
1、$:匹配輸入行尾。如果設置了RegExp對象的Multiline屬性,$也匹配「 」或「 」之前的位置。
2、*:匹配前面的子表達式任意次。例如,zo*能匹配「z」,也能匹配「zo」以及「zoo」。*等價於{0,}。
3、+:匹配前面的子表達式一次或多次(大於等於1次)。例如,「zo+」能匹配「zo」以及「zoo」,但不能匹配「z」。+等價於{1,}。
4、?:匹配前面的子表達式零次或一次。例如,「do(es)?」可以匹配「do」或「does」。?等價於{0,1}。
5、{n,}:n是一個非負整數。至少匹配n次。例如,「o{2,}」不能匹配「Bob」中的「o」,但能匹配「foooood」中的所有o。「o{1,}」等價於「o+」。「o{0,}」則等價於「o*」。
❼ java中的int的取值范圍如何計算
1、java中int的取值范圍為-2147483648到+-2147483648。
2、首先jdk中定義int佔4個位元組32位,32位就是jvm僅僅給分配32個格子的空間,用以存放數據。
3、計算機中用0和1存放數據。那麼,32個格子中放滿0或1的方法,有2的32次方種。
4、但是java中int有正負之分,所以32個格子中佔用一個格子標識正負,僅僅能用31個格子來標識數值。最後int能標識的最大/最小數字是:2的31次方即+/-2147483648。取值范圍即為二者之間。
(7)int小數java擴展閱讀:
一位元組表示八位,即:1byte = 8 bit;
int: 4byte = 32 bit 有符號signed范圍:2^31-1 ~ -2^31即:2147483647 ~ -2147483648無符號unsigned范圍:2^32-1 ~ 0即:4294967295 ~ 0
long: 4 byte = 32 bit 同int型
double: 8 byte = 64 bit 范圍:1.79769e+308 ~ 2.22507e-308
long double: 12 byte = 96 bit 范圍: 1.18973e+4932 ~ 3.3621e-4932
float: 4 byte = 32 bit 范圍: 3.40282e+038 ~ 1.17549e-038