基本數據類型

来源:http://www.cnblogs.com/z360519549/archive/2016/11/17/6075946.html
-Advertisement-
Play Games

byte tt=(byte)130 等於 -126 。 byte 占一個位元組,8bit 。第一位是符號位,0 表示正數,1 表示負數。因此byte 的取值範圍 [-128, 127] 。 130的二進位是00000000000000000000000010000010,截取成byte類型只保留後8位 ...


byte tt=(byte)130  等於 -126 。 byte 占一個位元組,8bit 。第一位是符號位,0 表示正數,1 表示負數。因此byte 的取值範圍 [-128, 127] 。

130的二進位是00000000000000000000000010000010,截取成byte類型只保留後8位,也就是10000010,第1位是符號位0代表正數、1代表負數,這裡第一位是1也就是負數,電腦存儲的負數是補碼,必須將其他位取反再加1,取反加1後這個為-1111110,這個二進位數轉換為整數是-126 。

byte a= (byte) 0x00000111;   十六進位 16*16 + 16 + 1 = 256 + 17 =  0000001  00010001 。截取後8位,則 a = 17 。

byte c = (byte)0xFF;  十六進位 15*16 + 15 = 255 = 11111111 , 最前面1表示負數, 存儲的是 補碼,後面7位取反 加 1 等於 1 , 則 c = -1 。   System.out.println(c);  輸入 -1 。

八進位必須以 0 開頭, 十進位不能以0開頭(0除外)。

byte a= 00000111;  八進位 64 + 8 + 1 , 則 a = 73 。

byte a= (byte)00001111; 八進位 8*8*8 + 64 + 8 + 1 = 00000010 01001001 , 轉換成byte,取後8位,則 a = 73 。   byte a= 00001111 ,會報錯超出範圍[-128,127] 。

 

byte占 8位。 short 占 16位,取值範圍 [-32768, 32767]

short s1 = 1; s1 = s1 + 1; 會報錯,因為1是int類型,計算結果是 int類型,需要強制轉換成short類型,寫成  s1 = (short)(s1 + 1) ;  或者 s1 += 1; 此種寫法含有隱式的強制類型轉換。 相當於(short)(s1 + 1)  

 

int類型在記憶體中占32位,4個位元組。取值範圍 [-2147483648, 2147483647]。

2^31 = 2147483648

 

Integer a = 3;
Integer b = 3;

System.out.println(a == b);   // true 。

 創建b 的時候,會先去已創建的對象里尋找是否有相同的值,有的話就使用地址,由於b的值和a的值是相同的,所以b是直接引用a 。如果 再執行 a = 4 ; 則會另創建一個值為4的對象,並把 a 指向 該對象。但是b 的指向不變。

Integer c = new Integer(3);

Integer d = new Integer(3);

System.out.println(a == c);  //false 。

System.out.println(d == c);  //false 。

另外創建兩個 值為 3的對象 c 和 d,和a 不同的地址。

int e = 3;

System.out.println(a == e); //true

a 會自動開箱,並用其值與 e 比較。相等。

System.out.println(d == e);  //true 

 

Integer f = Integer.valueOf(3);

System.out.println(a == f);  //true

Integer.valueOf(3) 返回一個 Integer 的對象,如果之前有此對象,則 f 也指向這個對象。

System.out.println(c == f);  //false 。

System.out.println(e == f); //true, 自動開箱後比較。

 

int a = Integer.parseInt("634");   parseInt() 是 Integer類的靜態方法,返回一個 int 的值 。參數必須是字元串。 a =634 。

int r = Integer.parseInt("s"); 會在運行時報錯:NumberFormatException 

Integer k = Integer.valueOf("634");   返回值是 634 的Integer 對象。

Integer k = Integer.valueOf("a"); 會在運行時報錯:NumberFormatException 

int a = Integer.parseInt("634" , 8); 第二個參數表示進位, 把第一個參數轉換成十進位的整數值,比如把 8進位的 634 轉化成 6*8*8 + 3*8 + 4 = 412 。

 

 

long型如果賦值超出int型的範圍,則需要在數字後加上L或l 。表示該值是長整型。long占64位。

long n = 2147483650L + 4; 則 n 值是 2147483654 。 

long m = (long)(2147483647 + 4);  計算過程:2147483647 存儲是: 01111111 11111111 11111111 11111111 加上 00000000 00000000 00000000 00000100 等於 10000000 00000000 00000000 00000011 。

前面的1 表示負數。負數存儲的是補碼,將其他位取反加 1 。 源碼是 11111111 11111111 11111111 11111101 。 則 m 等於 -(2^32-1-2)= -2147483645 。

 

float 占32位。申明float 變數必須在小數後面加F 或 f 。

double占64位。預設小數是 double 。也可以在後面加D 或 d 。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 首先需要說明的是這是.net framework的一個組件,而不是針對.net core的。目前工作比較忙,因此.net core的轉換正在編寫過程中,有了實現會第一時間貼出來。 接下來進入正題。對於大型的分層系統,會有一個應用程式層,應用程式層的主要作用是封裝業務領域層的業務邏輯層,並對界面展示層 ...
  • 在上一篇文章中我們創建了WCF服務端應用程式,在這一篇文章中我們來學習如何創建WCF的服務端寄宿程式與客戶端調用程式。 ...
  • 環境準備 1、亞馬遜EC2 Windows Server 2016 with Container 2、Visual Studio 2015 Enterprise(Profresianal要裝Update 3) 3、.NET Core 1.0.0 – VS 2015 Tooling Preview 2 ...
  • .NET Core 1.1 RTM 版2016/11/16 發佈。對應發佈 ASP.NET Core 1.1 、EF Core 1.1。 你可以通過Visual Studio 2015, Visual Studio 2017 RC, Visual Studio Code and Visual Stu ...
  • 一. Xcode 環境安裝 與 工程創建 1. 下載環境 相關資源下載 : -- IOS 相關資料下載頁面 : https://developer.apple.com/devcenter/ios/index.action ; -- Xcode 下載頁面 : https://developer.app ...
  • 1. echo和print的區別 echo沒有返回值,print有返回值1,執行失敗時返回false;echo輸出的速度比print快,因為沒有返回值;echo可以輸出一個或多個字元串,print只允許輸出一個字元串;print可以用於複雜的表達式,echo不行。 另問:echo是個函數嗎? ech ...
  • 在PHP面試中,經常碰到此題 :要求寫出5種以上的方法,獲取一個文件的擴展名,其實也是在考察面試者基礎知識的掌握程度,下麵整理了幾種常用的方法(下麵方法返回的都是不帶’.'的,如果要求帶 ‘.’的話 自己改一下): <?php $file = ‘siyuantlw/程式設計.php’; functi ...
  • 包裝類 基本類型 包裝類 + byte Byte + short Short + int Integer + long Long + char Character + float Float + double Double + boolean Boolean 基本類型轉為包裝類型: + 自動裝箱Au ...
一周排行
    -Advertisement-
    Play Games
  • Dapr Outbox 是1.12中的功能。 本文只介紹Dapr Outbox 執行流程,Dapr Outbox基本用法請閱讀官方文檔 。本文中appID=order-processor,topic=orders 本文前提知識:熟悉Dapr狀態管理、Dapr發佈訂閱和Outbox 模式。 Outbo ...
  • 引言 在前幾章我們深度講解了單元測試和集成測試的基礎知識,這一章我們來講解一下代碼覆蓋率,代碼覆蓋率是單元測試運行的度量值,覆蓋率通常以百分比表示,用於衡量代碼被測試覆蓋的程度,幫助開發人員評估測試用例的質量和代碼的健壯性。常見的覆蓋率包括語句覆蓋率(Line Coverage)、分支覆蓋率(Bra ...
  • 前言 本文介紹瞭如何使用S7.NET庫實現對西門子PLC DB塊數據的讀寫,記錄了使用電腦模擬,模擬PLC,自至完成測試的詳細流程,並重點介紹了在這個過程中的易錯點,供參考。 用到的軟體: 1.Windows環境下鏈路層網路訪問的行業標準工具(WinPcap_4_1_3.exe)下載鏈接:http ...
  • 從依賴倒置原則(Dependency Inversion Principle, DIP)到控制反轉(Inversion of Control, IoC)再到依賴註入(Dependency Injection, DI)的演進過程,我們可以理解為一種逐步抽象和解耦的設計思想。這種思想在C#等面向對象的編 ...
  • 關於Python中的私有屬性和私有方法 Python對於類的成員沒有嚴格的訪問控制限制,這與其他面相對對象語言有區別。關於私有屬性和私有方法,有如下要點: 1、通常我們約定,兩個下劃線開頭的屬性是私有的(private)。其他為公共的(public); 2、類內部可以訪問私有屬性(方法); 3、類外 ...
  • C++ 訪問說明符 訪問說明符是 C++ 中控制類成員(屬性和方法)可訪問性的關鍵字。它們用於封裝類數據並保護其免受意外修改或濫用。 三種訪問說明符: public:允許從類外部的任何地方訪問成員。 private:僅允許在類內部訪問成員。 protected:允許在類內部及其派生類中訪問成員。 示 ...
  • 寫這個隨筆說一下C++的static_cast和dynamic_cast用在子類與父類的指針轉換時的一些事宜。首先,【static_cast,dynamic_cast】【父類指針,子類指針】,兩兩一組,共有4種組合:用 static_cast 父類轉子類、用 static_cast 子類轉父類、使用 ...
  • /******************************************************************************************************** * * * 設計雙向鏈表的介面 * * * * Copyright (c) 2023-2 ...
  • 相信接觸過spring做開發的小伙伴們一定使用過@ComponentScan註解 @ComponentScan("com.wangm.lifecycle") public class AppConfig { } @ComponentScan指定basePackage,將包下的類按照一定規則註冊成Be ...
  • 操作系統 :CentOS 7.6_x64 opensips版本: 2.4.9 python版本:2.7.5 python作為腳本語言,使用起來很方便,查了下opensips的文檔,支持使用python腳本寫邏輯代碼。今天整理下CentOS7環境下opensips2.4.9的python模塊筆記及使用 ...