java⼋⼤基本数据类型及其封装类
1. Java的简单类型及其封装器类
Java基本类型共有⼋种,基本类型可以分为三类,字符类型char,布尔类型boolean以及数值类型byte、short、int、long、float、double。数值类型⼜可以分为整数类型byte、short、int、long和浮点数类型float、double。JAVA中的数值类型不存在⽆符号的,它们的取值范围是固定的,不会随着机器硬件环境或者的改变⽽改变。实际上,JAVA中还存在另外⼀种基本类型void,它也有对应的包装类java.lang.Void,不过我们⽆法直接对它们进⾏操作。8 中类型表⽰范围如下:
byte:8位,最⼤存储数据量是255,存放的数据范围是-128~127之间。
short:16位,最存储量是65536,数据范围是-32768~32767之间。
int:32位,最⼤数据存储容量是2的32次⽅减1,数据范围是负的2的31次⽅到正的2的31次⽅减1。
long:64位,最⼤数据存储容量是2的64次⽅减1,数据范围为负的2的63次⽅到正的2的63次⽅减1。
float:32位,数据范围在3.4e-45~1.4e38,直接赋值时必须在数字后加上f或F。
double:64位,数据范围在4.9e-324~1.8e308,赋值时可以加d或D也可以不加。
boolean:只有true和false两个取值。
char:16位,存储Unicode码,⽤单引号赋值。
Java决定了每种简单类型的⼤⼩。这些⼤⼩并不随着机器结构的变化⽽变化。这种⼤⼩的不可更改正是Java程序具有很强移植能⼒的原因之⼀。下表列出了Java中定义的简单类型、占⽤⼆进制位数及对应的封装器类。
简单类型boolean byte char short Int long float double void
⼆进制位数18161632643264--
封装器类Boolean Byte Character Short Integer Long Float Double Void
对于数值类型的基本类型的取值范围,我们⽆需强制去记忆,因为它们的值都已经以常量的形式定义在对应的包装类中了。如:
基本类型byte ⼆进制位数:Byte.SIZE最⼩值:Byte.MIN_VALUE最⼤值:Byte.MAX_VALUE
基本类型short⼆进制位数:Short.SIZE最⼩值:Short.MIN_VALUE最⼤值:Short.MAX_VALUE
基本类型char⼆进制位数:Character.SIZE最⼩值:Character.MIN_VALUE最⼤值:Character.MAX_VALUE
基本类型double ⼆进制位数:Double.SIZE最⼩值:Double.MIN_VALUE最⼤值:Double.MAX_VALUE
注意:float、double两种类型的最⼩值与Float.MIN_VALUE、 Double.MIN_VALUE的值并不相同,实际上Float.MIN_VALUE和Double.MIN_VALUE分别指的是 float和double类型所能表⽰的最⼩正数。也就是说存在这样⼀种情况,0到±Float.MIN_VALUE之间的值float类型⽆法表⽰,0 到±Double.MIN_VALUE之间的值double类型⽆法表⽰。这并没有什么好奇怪的,因为这些范围内的数值超出了它们的精度范围。
Float和Double的最⼩值和最⼤值都是以科学记数法的形式输出的,结尾的"E+数字"表⽰E之前的数字要乘以10的多少倍。⽐如3.14E3就是3.14×1000=3140,3.14E-3就是3.14/1000=0.00314。
Java基本类型存储在栈中,因此它们的存取速度要快于存储在堆中的对应包装类的实例对象。从Java5.0(1.5)开始,JAVA虚拟机(Virtual Machine)可以完成基本类型和它们对应包装类之间的⾃动转换。因此我们在赋值、参数传递以及数学运算的时候像使⽤基本类型⼀样使⽤它们的包装类,但这并不意味着你可以通过基本类型调⽤它们的包装类才具有的⽅法。另外,所有基本类型(包括void)
的包装类都使⽤了final修饰,因此我们⽆法继承它们扩展新的类,也⽆法重写它们的任何⽅法。
基本类型的优势:数据存储相对简单,运算效率⽐较⾼
包装类的优势:有的容易,⽐如集合的元素必须是对象类型,满⾜了java⼀切皆是对象的思想
2.Java中的常量
⼗六进制整型常量:以⼗六进制表⽰时,需以0x或0X开头,如0xff,0X9A。
⼋进制整型常量:⼋进制必须以0开头,如0123,034。
长整型:长整型必须以L作结尾,如9L,342L。
浮点数常量:由于⼩数常量的默认类型是double型,所以float类型的后⾯⼀定要加f(F)。同样带⼩数的变量默认为double类型。
如:float f;
f=1.3f;//必须声明f。
字符常量:字符型常量需⽤两个单引号括起来(注意字符串常量是⽤两个双引号括起来)。Java中的字符占两个字节。⼀些常⽤的转义字符:
①\r表⽰接受键盘输⼊,相当于按下了回车键;
②\n表⽰换⾏;
③\t表⽰制表符,相当于Table键;
④\b表⽰退格键,相当于Back Space键;
⑤\'表⽰单引号;
⑥\''表⽰双引号;
⑦\\表⽰⼀个斜杠\。
3. 数据类型之间的转换
1).简单类型数据间的转换,有两种⽅式:⾃动转换和强制转换,通常发⽣在表达式中或⽅法的参数传递时。
⾃动转换
具体地讲,当⼀个较"⼩"数据与⼀个较"⼤"的数据⼀起运算时,系统将⾃动将"⼩"数据转换成"⼤"数据,再进⾏运算。⽽在⽅法调⽤时,实际参数较"⼩",⽽被调⽤的⽅法的形式参数数据⼜较"⼤"时(若有匹配的,当然会直接调⽤匹配的⽅法),系统也将⾃动将"⼩"数据转换成"⼤"数据,再进⾏⽅法的调⽤,⾃然,对于多个同名的重载⽅法,会转换成最"接近"的"⼤"数据并进⾏调⽤。这些类型由"⼩"到"⼤"分别为 (byte,short,char)--int--long--float—double。这⾥我们所说的"⼤"与"⼩",并不是指占⽤字节的多少,⽽是指表⽰值的范围的⼤⼩。
①下⾯的语句可以在Java中直接通过:
byte b;int i=b; long l=b; float f=b; double d=b;
②如果低级类型为char型,向⾼级类型(整型)转换时,会转换为对应ASCII码值,例如
char c='c'; int i=c;
System.out.println("output:"+i);输出:output:99;
③对于byte,short,char三种类型⽽⾔,他们是平级的,因此不能相互⾃动转换,可以使⽤下述的强制类型转换。
short i=99 ; char c=(char)i; System.out.println("output:"+c);输出:output:c;
强制转换
将"⼤"数据转换为"⼩"数据时,你可以使⽤强制类型转换。即你必须采⽤下⾯这种语句格式: int n=(int)3.14159/2;可以想象,这种转换肯定可能会导致溢出或精度的下降。
2)表达式的数据类型⾃动提升, 关于类型的⾃动提升,注意下⾯的规则。
①所有的byte,short,char型的值将被提升为int型;
②如果有⼀个操作数是long型,计算结果是long型;
③如果有⼀个操作数是float型,计算结果是float型;
④如果有⼀个操作数是double型,计算结果是double型;
例, byte b; b=3; b=(byte)(b*3);//必须声明byte。
3)包装类过渡类型转换
⼀般情况下,我们⾸先声明⼀个变量,然后⽣成⼀个对应的包装类,就可以利⽤包装类的各种⽅法进⾏类型转换了。例如:
①当希望把float型转换为double型时:
float f1=100.00f;
Float F1=new Float(f1);
double d1=F1.doubleValue();//F1.doubleValue()为Float类的返回double值型的⽅法
②当希望把double型转换为int型时:
double d1=100.00;
Double D1=new Double(d1);
int i1=D1.intValue();
简单类型的变量转换为相应的包装类,可以利⽤包装类的构造函数。即:Boolean(boolean value)、Character(char value)、Integer(int value)、Long(long value)、Float(float value)、Double(double val
ue)
⽽在各个包装类中,总有形为××Value()的⽅法,来得到其对应的简单类型数据。利⽤这种⽅法,也可以实现不同数值型变量间的转换,例如,对于⼀个双精度实型类,intValue()可以得到其对应的整型变量,⽽doubleValue()可以得到其对应的双精度实型变量。
4)字符串与其它类型间的转换
其它类型向字符串的转换
①调⽤类的串转换⽅法:X.toString();
②⾃动转换:X+"";
③使⽤String的⽅法:String.volueOf(X);
字符串作为值,向其它类型的转换
①先转换成相应的封装器实例,再调⽤对应的⽅法转换成其它类型
例如,字符中"32.1"转换double型的值的格式为:new Float("32.1").doubleValue()。也可以⽤:Double.v
alueOf("32.1").doubleValue()
②静态parseXXX⽅法
String s = "1";
byte b = Byte.parseByte( s );
short t = Short.parseShort( s );
int i = Integer.parseInt( s );
long l = Long.parseLong( s );
Float f = Float.parseFloat( s );
Double d = Double.parseDouble( s );
③Character的getNumericValue(char ch)⽅法
5)Date类与其它数据类型的相互转换
整型和Date类之间并不存在直接的对应关系,只是你可以使⽤int型为分别表⽰年、⽉、⽇、时、分、秒,这样就在两者之间建⽴了⼀个对应关系,在作这种转换时,你可以使⽤Date类构造函数的三种形式:
①Date(int year, int month, int date):以int型表⽰年、⽉、⽇
②Date(int year, int month, int date, int hrs, int min):以int型表⽰年、⽉、⽇、时、分
③Date(int year, int month, int date, int hrs, int min, int sec):以int型表⽰年、⽉、⽇、时、分、秒
bigdecimal转换为integer在长整型和Date类之间有⼀个很有趣的对应关系,就是将⼀个时间表⽰为距离格林尼治标准时间1970年1⽉1⽇0时0分0秒的毫秒数。对于这种对应关系,Date类也有其相应的构造函数:Date(long date)。
获取Date类中的年、⽉、⽇、时、分、秒以及星期你可以使⽤Date类的getYear()、getMonth()、getDate()、getHours()、getMinutes()、getSeconds()、getDay()⽅法,你也可以将其理解为将Date类转换成int。
⽽Date类的getTime()⽅法可以得到我们前⾯所说的⼀个时间对应的长整型数,与包装类⼀样,Date类也有⼀个toString()⽅法可以将其转换为String类。
有时我们希望得到Date的特定格式,例如20020324,我们可以使⽤以下⽅法,⾸先在⽂件开始引⼊,
SimpleDateFormat;
import java.util.*;
java.util.Date date = new java.util.Date();
//如果希望得到YYYYMMDD的格式
SimpleDateFormat sy1=new SimpleDateFormat("yyyyMMDD");
String dateFormat=sy1.format(date);
//如果希望分开得到年,⽉,⽇
SimpleDateFormat sy=new SimpleDateFormat("yyyy");
SimpleDateFormat sm=new SimpleDateFormat("MM");
SimpleDateFormat sd=new SimpleDateFormat("dd");
String syear=sy.format(date);
String smon=sm.format(date);
String sday=sd.format(date);
总结:只有boolean不参与数据类型的转换
(1).⾃动类型的转换:a.常数在表数范围内是能够⾃动类型转换的
b.数据范围⼩的能够⾃动数据类型⼤的转换(注意特例)
int到float,long到float,long到double 是不会⾃动转换的,不然将会丢失精度
c.引⽤类型能够⾃动转换为⽗类的
d.基本类型和它们包装类型是能够互相转换的
(2).强制类型转换:⽤圆括号括起来⽬标类型,置于变量前
4.Java引⽤类型
Java有 5种引⽤类型(对象类型):类 接⼝ 数组 枚举 标注
引⽤类型:底层结构和基本类型差别较⼤
JVM的内存空间:(1). Heap 堆空间:分配对象 new Student()
(2). Stack 栈空间:临时变量 Student stu
(3).Code 代码区 :类的定义,静态资源 Student.class
eg:Student stu = new Student(); //new 在内存的堆空间创建对象
stu.study(); //把对象的地址赋给stu引⽤变量
上例实现步骤:a.JVM加载Student.class 到Code区
c.将此实例的地址赋值给引⽤stu, 栈空间;
-----------------------------------------  个⼈总结 -----------------------------------------
上⾯是转载别⼈的⽂章,下⾯做个总结:
1、如果⼩数类型,并且⼩数⽐较⼩,⽐如四位⼩数,建议使⽤ BigDecimal 如果 是 double 类型会有失精度,有的时候会⽤科学记数法表⽰;
⽐如 0.0001 会变成 1.0E-4,试问谁能看懂,如果偏要⽤ double 还要对类型进⾏转换。
2、int double 都是有包装类型的,建议使⽤包装类型,包装类型能区分 null 和 0,就像在spring-mvc接收时使⽤ int 类型接收值,如果这个属性不传值,ajax 请求会报 400 错误,⽽且不能区分这个值是否是空;
3、for 循环中如果要对字符串进⾏拼接,建议使⽤ StringBuffer ,如果没有线程安全问题,直接使⽤ StringBuilder,原因StringBuffer 的所有操作是保证线程安全的,可以理解成使⽤了 synchronized 关键字,对性能是有影响的。
4、最后对所有包装类型进⾏操作(⽐如 toString())要进⾏空指针判断,我们并不能保证这个值是有的。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。