隨筆 - 26  文章 - 2  trackbacks - 0
          <2011年10月>
          2526272829301
          2345678
          9101112131415
          16171819202122
          23242526272829
          303112345

          常用鏈接

          留言簿

          隨筆檔案

          搜索

          •  

          最新評論

          閱讀排行榜

          評論排行榜


          Java語法總結 - 基本數據類型

          Java不是純的面向對象的語言,不純的地方就是這些基本數據類型不是對象。當然初期Java的運行速度很慢,基本數據類型能在一定程度上改善性能。如果你想編寫純的面向對象的程序,用包裝器類是取代基本數據類型就可以了。

          1、基本類型的存儲空間。byte--8位,short--16位,int--32位,long--64位,float--32位,double--64位。這六種數字類型都是有符號的。固定的存儲空間正是Java可移植性、跨平臺的原因之一!

          2、基本類型的存在導致了Java OOP的不純粹性。因為基本類型不是對象,一切皆對象是個小小的謊言。這是出于執行效率的權衡。

          3、使用公式-2的(位數-1)次冪到2的(位數-1)次冪-1確定整數類型的范圍(byte、short、int、long)。

          4、char是16位Unicode字符或者說是16位無符號整數,范圍從0到65535。即便如此,可以強制轉換非法的數據,如:char c1 = (char) 10000;  char c2 = (char) -200;。可以從二進制存儲的角度理解這點。

          5、整數有八進制(以0開頭的整數)、十進制、十六進制(以0x或0X開頭的整數)表示。

          6、char可以用單引號表示單個字符,如:'良'。也可以用unicode值'"ucafe'(四位十六進制數)。

          7、布爾型boolean。布爾型只能是true或者false,并且測試它為真還是假。它不能進行任何其他的運算,或者轉化為其他類型。
          正例:boolean b1 = 1 > 2;    反例:int seen = button.isVisible();
          實踐:簡潔是美德,請不要這樣寫:if ( is == true && done == false ) ,只有新手才那么寫。
          對于任何程序員 if ( whether && !done ) 都不難理解吧。所以去掉所有的==fasle 和 ==true。

          8、默認的浮點類型是雙精度(double),要想要一個float必須在浮點數后面加F或者f。如:float pi = 3.14;是錯誤的。

          9、默認的整數類型是int型,要想使用長整型可在后面加“l”或“L”,如:1000L。(小寫l容易被誤認為1,不推薦用)

          10、float可以精確到7位有效數字,第8位的數字是第9位數字四舍五入上取得的;double可以精確到16位有效數字,第17位的數字是第18位數字四舍五入上取得的。蓋茨到底有多少錢?要用double表示,用float是裝不下的……

          11、如果要求精確的答案,請不要使用float和double,因為它們是為了在廣域數值范圍上提供較為精確的快速近似運算而精心設計的。然而,它們沒有提供完全精確的結果。尤其是對貨幣計算尤為不適合,因為要讓一個float或double精確地表達0.1(或者10的任何)

          12、BigInteger支持任意精度的整數。BigDecimal支持任意精度的定點數。

          13、初始化無論怎么強調都不過分!Java為所有的成員變量提供了默認初始化:byte、short、 int、long--0  float--0.0f double--0.0  boolean--false  char--'"u0000',特別地對象類型的引用全被初始化為null。(注意!除了數組之外的局部變量是得不到這種優待的,需要你自己初始化。另外,默認初始化的值是你想要的嗎?所以最好明確地對變量進行初始化,一般是在構造函數中。)

          14、基本類型之間的轉化。Java的類型檢查很嚴格,從低精度轉換到高精度是無須顯式轉換的,double d = 123;。但是反過來,進行窄化轉換,由高精度向低精度,或者一種類型到另一種類型,則必須使用強制類型轉化。Java提供了安全轉化機制,但是結果是否是期望的,你自己保證吧。
          double d = 12.5;
          float f = (int) d; //結果不是13,而是12!
          浮點型轉化為整型時,不進行四舍五入,直接截斷小數點后面的數。

          15、提升。各種基本數據類型進行混合運算,結果會是表達能力最強的那種。如:int和long運算,結果是long,整型和浮點型運算結果是浮點型。特殊的一點是:只要類型比int小(如char、byte、short),那么在運算之前,這些值會自動地轉換成int。例子:
          byte b1 = 12;
          byte b2 = b1 + 1; //在編譯時出錯了!因為b1+1已經是int型了!切記!

          16、浮點類型的科學表示法。在數學中e代表自然對數(Math.E給出了double值),而在Java中e代表10的冪次。浮點型的數可以這樣表示float f = 1e-27f; 代表1乘以10的負27次冪。
          posted on 2011-10-09 21:31 Java_liyadong 閱讀(227) 評論(0)  編輯  收藏

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


          網站導航:
           
          主站蜘蛛池模板: 怀仁县| 惠东县| 大荔县| 桂平市| 巴楚县| 巧家县| 株洲市| 桐城市| 普格县| 新干县| 谢通门县| 株洲县| 蓬安县| 磐石市| 水城县| 丁青县| 太原市| 抚远县| 石城县| 沂水县| 义乌市| 金华市| 浑源县| 定襄县| 浦江县| 同江市| 二手房| 石景山区| 双城市| 佛学| 陆河县| 巴彦淖尔市| 永城市| 高邮市| 大方县| 东乌珠穆沁旗| 获嘉县| 武清区| 华容县| 克东县| 清新县|