Java的数据结构总结

版权声明:每个人都是自己的上帝。如果你自己都放弃自己了,还有谁会救你?------《肖申克的救赎》本文为博主原创文章,欢迎转载(记得注明出处,拜托~)。 https://blog.csdn.net/hu_belif/article/details/83578479

 Java 基本数据类型总结

在Java的代码重构中,我们不得不承认若是不了解jvm的内存原理或是数据类型,我们根本读不懂那些乱七八糟的数据参数。

变量就是申请内存来存储值。也就是说,当创建变量的时候,需要在内存中申请空间;内存管理系统根据变量的类型为变量分配存储空间,分配的空间只能用来储存该类型数据。

因此,通过定义不同类型的变量,可以在内存中储存整数、小数或者字符。

Java 的两大数据类型:

  • 内置数据类型
  • 引用数据类型

内置数据类型

又叫基本数据类型(共八种):
整型4种,浮点型两种,布尔型与字符型各一种。
整型在内存中采用补码的形式存储(只有整型有进制的概念);

浮点型在内存中分三块存储:符号(1位),指数(8位),尾数(23位)(整型与浮点类型都属于数值类型number类)
 

内置数据类型(基本数据类型)
类型 字节大小 取值范围 定义
long 8byte -2^63~2^63-1 在尾部加L或l尾部标识,可加可不加
int 4byte -2^63~2^63-1
short 2byte -2^63~2^63-1
byte 1byte -2^63~2^63-1
float 4byte   在尾部加F或f尾部标识,必须加
double 8byte   在尾部加D或d尾部标识,可加可不加
boolean 1bit false或true
char 2byte ‘\u0000’~'\uffff' char   test = 'test';
基本数据类型的包装类
类型 包装类型
long Long
int Integer
short Short
byte Byte
float Float
double Double
boolean Boolean
char Charactor


 

             
注意进制的定义:
八进制定义---在数值开头加上0    eg:int    test  =  01;
十六进制定义---在数值开头加上0x   eg:  int   test  =  0x1;

引用数据类型

引用数据类型分为:

①:String、集合(collections)、枚举(enum)等类类型

②:数组

③:接口

  • 在Java中,引用类型的变量非常类似于C/C++的指针。引用类型指向一个对象,指向对象的变量是引用变量。这些变量在声明时被指定为一个特定的类型,比如 Employee、Puppy 等。变量一旦声明后,类型就不能被改变了。
  • 对象、数组都是引用数据类型。
  • 所有引用类型的默认值都是null。
  • 一个引用变量可以用来引用任何与之兼容的类型。
  • 例子:Site site = new Site("Runoob")。

Java 常量

常量在程序运行时是不能被修改的。

在 Java 中使用 final 关键字来修饰常量,声明方式和变量类似:

final double PI = 3.1415927;

虽然常量名也可以用小写,但为了便于识别,通常使用大写字母表示常量。

字面量可以赋给任何内置类型的变量。例如:

byte a = 68;
char a = 'A'

byte、int、long、和short都可以用十进制、16进制以及8进制的方式来表示。

当使用常量的时候,前缀 0 表示 8 进制,而前缀 0x 代表 16 进制, 例如:

int decimal = 100;
int octal = 0144;
int hexa =  0x64;

和其他语言一样,Java的字符串常量也是包含在两个引号之间的字符序列(有若干个字符按一定顺序组成的数据序列)。下面是字符串型字面量的例子:

"Hello World"
"two\nlines"
"\"This is in quotes\""

字符串常量和字符常量都可以包含任何Unicode字符。例如:

char a = '\u0001';
String a = "\u0001";

Java语言支持一些特殊的转义字符序列。

符号 字符含义
\n 换行 (0x0a)
\r 回车 (0x0d)
\f 换页符(0x0c)
\b 退格 (0x08)
\0 空字符 (0x20)
\s 字符串
\t 制表符
\" 双引号
\' 单引号
\\ 反斜杠
\ddd 八进制字符 (ddd)
\uxxxx 16进制Unicode字符 (xxxx)

自动类型转换

整型、实型(常量)、字符型数据可以混合运算。运算中,不同类型的数据先转化为同一类型,然后进行运算。

转换从低级到高级。

低  ------------------------------------>  高

byte,short,char—> int —> long—> float —> double 

数据类型转换必须满足如下规则:

  • 1. 不能对boolean类型进行类型转换。

  • 2. 不能把对象类型转换成不相关类的对象。

  • 3. 在把容量大的类型转换为容量小的类型时必须使用强制类型转换。

  • 4. 转换过程中可能导致溢出或损失精度,例如:

    int i =128;   
    byte b = (byte)i;

    因为 byte 类型是 8 位,最大值为127,所以当 int 强制转换为 byte 类型时,值 128 时候就会导致溢出。

  • 5. 浮点数到整数的转换是通过舍弃小数得到,而不是四舍五入,例如:

    (int)23.7 == 23;        
    (int)-45.89f == -45

自动类型转换

必须满足转换前的数据类型的位数要低于转换后的数据类型,例如: short数据类型的位数为16位,就可以自动转换位数为32的int类型,同样float数据类型的位数为32,可以自动转换为64位的double类型。

实例

public class ZiDongLeiZhuan{ 
        public static void main(String[] args){
             char c1='a';//定义一个char类型 int i1 = c1;//char自动类型转换为int                     
             System.out.println("char自动类型转换为int后的值等于"+i1); 
             char c2 = 'A';//定义一个char类型 
             int i2 = c2+1;//char 类型和 int 类型计算 
             System.out.println("char类型和int计算后的值等于"+i2); 
    } 
}

运行结果为:

char自动类型转换为int后的值等于97
char类型和int计算后的值等于66

解析:c1 的值为字符 a ,查 ASCII 码表可知对应的 int 类型值为 97, A 对应值为 65,所以 i2=65+1=66。

强制类型转换

  • 1. 条件是转换的数据类型必须是兼容的。

  • 2. 格式:(type)value type是要强制类型转换后的数据类型 实例:

    实例

    public class QiangZhiZhuanHuan{ public static void main(String[] args){ int i1 = 123; byte b = (byte)i1;//强制类型转换为byte System.out.println("int强制类型转换为byte后的值等于"+b); } }
    
    运行结果:
    
    int强制类型转换为byte后的值等于123

隐含强制类型转换

  • 1. 整数的默认类型是 int。

  • 2. 浮点型不存在这种情况,因为在定义 float 类型时必须在数字后面跟上 F 或者 f。

下一篇:Java程序员面试,自动封箱/拆箱原理与包装类的缓冲机制你知道么?

猜你喜欢

转载自blog.csdn.net/hu_belif/article/details/83578479