首页 > 编程知识 正文

列举java八种基本数据类型,java的八大基本类型

时间:2023-05-05 07:27:51 阅读:139725 作者:4403

byte数据类型是由8位、有符号、二进制补数表示的整数; (Byte )

short数据类型是由有符号的16位二进制补码表示的整数。 (Short )

int数据类型是用32比特、有符号的二进制补数表示的整数; (Integer )

长数据类型为64位,是用带符号的二进制补数表示的整数; (Long )

浮点数据类型为单精度、32位、符合IEEE 754标准的浮点数; (Float )

双精度数据类型是双精度、64位、符合IEEE 754标准的浮点数; (Double )

布尔数据类型表示1比特信息; (布尔)

char型是单个16位Unicode字符; (Character )

基本数据类型的优点:因为它存储在堆栈中,所以比存储在堆中的对应包装类的实例访问速度更快,数据存储相对简单,处理效率更高

1 .比特是比特。 也称为位,是计算机表示最小数据的单位。 2.byte是字节3.1byte=8bit,0001 1100,一般用两个十六进制表示。 因此,我们经常会看到1B Java的简单类型及其包装类,一个字节显示为1c4.1byte

Java的基本类型共有8种,基本类型可以分为3种:

字符类型char

布尔型布尔型

数值类型byte、short、int、long、float、double

数值型还可以分为整数型byte、short、int、long、浮点数型float、double。 JAVA数值类型没有符号,取值范围是固定的,不会随计算机硬件环境或操作系统的变化而变化。 实际上,JAVA中还存在着另一种基本类型的void。 它还有对应的包类java.lang.Void,但无法直接对其进行操作。 中型的显示范围如下。

byte:8位,最大存储数据量为255,保存的数据范围在-128~127之间。

短: 16位,最大数据存储量为65536,数据范围在-32768~32767之间。

int:32位,最大数据存储容量为2的32次方减去1,数据范围为负2的31次方减去正2的31次方。

长: 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。

布尔:只有true和false两个值。

char:16位,存储unicode,用单引号赋值。

Java按简单的类型决定大小。 这些大小并不随机器结构的变化而变化。 这个大小的不可更改性是Java程序具有良好可移植性的原因之一。 下表列出了Java中定义的简单类型、占用的二进制位数和相应的包类。

对于数字类型基本类型的取值范围,不需要强制记住,因为值在相应的包类中定义为常量。 例如:

基本型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 0到Float.MIN_VALUE的值float类型无法表示,0到Double.MIN_VALUE的值double类型可能无法表示。 这并不奇怪。 因为这些范围内的数值超出了精度范围。

Float和Double的最小值和最大值都是以科学记数法的形式输出的,末尾的' e数字'表示将e之前的数字变为10的几倍。 例如3.14E3是3.141000=3140,而3.14E3是3.14/1000=0.00314。

因为Java基本类型存储在堆栈中,所以它的访问速度比存储在堆中的相应包装类的实例对象快。 从JAVA5.0(1.5 )开始,Java虚拟机(JavaVirtual Machine )可以完成基本类型及其对应包装类之间的自动转换。 因此,使用包类进行赋值、传递参数和数学运算的方式与使用基本类型相同,但这并不意味着可以从基本类型调用包

装类才具有的方法。另外,所有基本类型(包括void)的包装类都使用了final修饰,因此我们无法继承它们扩展新的类,也无法重写它们的任何方法。

基本类型的优势:数据存储相对简单,运算效率比较高

包装类的优势:有的容易,比如集合的元素必须是对象类型,满足了java一切皆是对象的思想

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键;

⑤’表示单引号;

⑥’'表示双引号;

⑦表示一个斜杠。

数据类型之间的转换
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 value)

而在各个包装类中,总有形为××Value()的方法,来得到其对应的简单类型数据。利用这种方法,也可以实现不同数值型变量间的转换,
例如,对于一个双精度实型类,intValue()可以得到其对应的整型变量,而doubleValue()可以得到其对应的双精度实型变量。

4)字符串与其它类型间的转换

其它类型向字符串的转换

①调用类的串转换方法:X.toString();

②自动转换:X+"";

③使用String的方法:String.volueOf(X);

字符串作为值,向其它类型的转换

①先转换成相应的封装器实例,再调用对应的方法转换成其它类型

例如,字符中"32.1"转换double型的值的格式为:new Float(“32.1”).doubleValue()。也可以用:Double.valueOf(“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型表示年、月、日、时、分、秒

在长整型和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,我们可以使用以下方法,首先在文件开始引入,

import java.text.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).强制类型转换:用圆括号括起来目标类型,置于变量前

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区
b.new Student()在堆空间分配空间并创建一个Student实例;
c.将此实例的地址赋值给引用stu, 栈空间;

----------------------------------------- 个人总结 -----------------------------------------

上面是转载别人的文章,下面做个总结:

如果小数类型,并且小数比较小,比如四位小数,建议使用 BigDecimal 如果 是 double类型会有失精度,有的时候会用科学记数法表示;
比如 0.0001 会变成 1.0E-4,试问谁能看懂,如果偏要用 double 还要对类型进行转换。

int double 都是有包装类型的,建议使用包装类型,包装类型能区分 null 和 0,就像在spring-mvc接收时使用 int
类型接收值,如果这个属性不传值,ajax 请求会报 400 错误,而且不能区分这个值是否是空;

for 循环中如果要对字符串进行拼接,建议使用 StringBuffer ,如果没有线程安全问题,直接使用StringBuilder,原因StringBuffer的所有操作是保证线程安全的,可以理解成使用了 synchronized
关键字,对性能是有影响的。

最后对所有包装类型进行操作(比如 toString())要进行空指针判断,我们并不能保证这个值是有的。

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。