bomberlhl

          統計

          留言簿(1)

          閱讀排行榜

          評論排行榜

          【轉】JAVA 基本數據類型 取值范圍

          先看一段代碼
          public class Hello{
              public static void main(String[] args){
                  int i  = 5 ,  j = 2;
                  System.out.println(i+j);
                  System.out.println(i-j);
                  System.out.println(i*j);
                  System.out.println(i/j);
              }
          }

          編譯運行完上面的代碼后會得到各條指令運行的結果:7,3,10,2
          這就是JAVA里面的加減乘除運算,為什么5除以2不等于2.5而等于2呢?這是因為這里做的是整數的四則運算,5除以2的結果是2,而余數為1,我們可以在上面的代碼上加上一條指令
          System.out.println(i%j);
          運行這個結果就會得到余數 1,這個 “%”執行的求余,或者叫取模。
          想要得到5/2=2.5這個結果,我們需要改變對i和j的定義
          把 int i = 5 ,  j=2;  改寫成double i =5 , j = 2;
          再編譯運行一次,會得到如下的結果: 7.0 , 3.0 , 10.0 , 2.5.
          可以看到結果都發生了變化,變成了帶小數點的,我們稱之為浮點型常量。
          跟前面的例子一樣,我們也使用了這樣的定義方法
          int i = 5,j = 2;
          Scanner s = new Scanner(System.in);
          前面說過,我們在這里是定義了一個Scanner類型的引用變量,它指向一個Scanner對象,但是這里跟以前有點不一樣(大概是java中僅有的幾處不一樣的地方了),我們定義了一個int型的變量i,然后把它的值賦成5(不是指向5),以后用到它的地方就相當于在用5做計算。
          int是我們常用到八種基本數據類型之一,它表示整數型。
          在JAVA中一共有八種基本數據類型,他們分別是
          byte、short、int、long、float、double、char、boolean
          整型
          其中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)
          可以看到byte和short的取值范圍比較小,而long的取值范圍太大,占用的空間多,基本上int可以滿足我們的日常的計算了,而且int也是使用的最多的整型類型了。
          在通常情況下,如果JAVA中出現了一個整數數字比如35,那么這個數字就是int型的,如果我們希望它是byte型的,可以在數據后加上大寫的B:35B,表示它是byte型的,同樣的35S表示short型,35L表示long型的,表示int我們可以什么都不用加,但是如果要表示long型的,就一定要在數據后面加“L”。

          浮點型
          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”。
          浮點型的數據是不能完全精確的,所以有的時候在計算的時候可能會在小數點最后幾位出現浮動,這是正常的。

          boolean型(布爾型)
          這個類型只有兩個值,true和false(真和非真)
          boolean t = true;
          boolean f = false;
          char型(文本型)
          用于存放字符的數據類型,占用2個字節,采用unicode編碼,它的前128字節編碼與ASCII兼容
          字符的存儲范圍在\u0000~\uFFFF,在定義字符型的數據時候要注意加' ',比如 '1'表示字符'1'而不是數值1,
          char c = ' 1 ';
          我們試著輸出c看看,System.out.println(c);結果就是1,而如果我們這樣輸出呢System.out.println(c+0);
          結果卻變成了49。
          如果我們這樣定義c看看
          char c = ' \u0031 ';輸出的結果仍然是1,這是因為字符'1'對應著unicode編碼就是\u0031
          char c1 = 'h',c2 = 'e',c3='l',c4='l',c5 = 'o';
          System.out.print(c1);System.out.print(c2);System.out.print(c3);System.out.print(c4);Sytem.out.print(c5);

          String
          在前面我們看到過這樣的定義:
          String s = "hello";
          System.out.println(s);跟上面的5條語句組合起來的效果是一樣的,那么String是個什么呢?String是字符串,它不是基本數據類型,它是一個類,但是它又是一個有一點點特殊的類,它有很多性質和基本數據類型很像,以后我們會慢慢看到這些。

          posted on 2009-12-01 18:03 異域流浪 閱讀(234) 評論(0)  編輯  收藏


          只有注冊用戶登錄后才能發表評論。


          網站導航:
           
          主站蜘蛛池模板: 西昌市| 本溪| 诏安县| 岢岚县| 馆陶县| 六枝特区| 滁州市| 泾川县| 任丘市| 密云县| 监利县| 麻江县| 康保县| 克东县| 荥阳市| 昆明市| 会泽县| 陇川县| 红原县| 湘阴县| 蓬莱市| 莆田市| 通辽市| 通渭县| 天等县| 仪征市| 平定县| 白水县| 偃师市| 前郭尔| 城口县| 启东市| 元阳县| 乌兰察布市| 东乌珠穆沁旗| 漠河县| 麻江县| 长治县| 中牟县| 湘潭市| 宁强县|