java的基本类型和类型转化
1、八种数据类型" title="基本数据类型">基本数据类型:
byte-short--int --long--float--double--char
2、八种基本类型所占字节空间
一、int
- 整数的直接量为int;
- 存储范围为:- -2147483648~2147483647 -2^31 ~ 2^31-1 -2^63~2^63-1
1.1 直接量表示直接写出的整数:
int a= 100;
整数直接量的数字必须在int的范围内;
除了进制书写形式外,整数的直接量也经常写为16进制数值,以OX或Ox或者8进制的0开头;
int c=0x10;//16进制整数直接量
int d=020;//8进制整数直接量
System.out,println(c);
System.out.println(d);
1.2 整形数据的除法运算中的取整:
除法运算保留整数部分,舍弃小数部分
1.3 运算时要防止溢出发生:
整数运算的溢出:两个整数进行运算时,其结果可能会超出整数的范围产生溢出
byte w=(byte)(127+1);
System.out.println(w);
二、long:
在表示较大整数的时候,int范围不够的情况下,范围:-2 63~2 63-1
表示long类型的直接量,需要以L或l结尾
long l1 = 2147483647;//对的
long l2 = 2147483648;//编译错误,超出整数直接量的范围,也就是int值得范围。
2.1 使用long类型进行较大整数的运算
较大整数:超过int范围的整数
long distance1 = 1000*365*24*299792458;//使用较大整数运算
System.out.println(distance1);//4个int相乘结果一定为int,则超出int范围导致溢出!
long distance2 = 1000*365*24*299792458L;
System.out.println(distance2);//4个int乘long,结果一定为long
2.1 通过时间毫秒数来存储日期和时间:
JDK提供了一个方法,返回1970年1月1日0点0分0秒到此时此刻所经历的毫秒数,其数据类型为long
三、double:
浮点数,小数,包含float和double
double类型的精度是float的两倍,因此double也叫双精度浮点数
3.1 浮点数的直接量为double类型
小数的写法有以下几种:
通常写法:3.14、314.0
科学计数法:
1.25E2、1.25e2、1.25E-2
eg:1.25E2 1.25*10^2=125.0
默认浮点直接量为double类型,如果需要表示float类型,则需要在末尾加F或f。float f=1.25F;
3.2 double运算时会出现舍入误差
二进制中无法精确的表示1/10,就和十进制无法精确表示1/3一样;
二进制表示10进制可能会误差
double money = 3.0;
double price =2.9;
System.out.println(money- price);//输出结果为0.100000000009 舍入误差!
四、char
本质是16位无符号的整数,对应的是字符集的编码;
采用的编码是Unicode编码(世界通用的定长字符集,所有字符都是16位)
4.1 对char类型遍历进行赋值
整数类型:0---65535之间的整数数值
字符直接量:用单引号括起来的内容就是字符的实际内容
Unicode形式:‘\u004e’、‘\u4e2d’,Unicode 的16进制形式
4.2 使用转义字符:
对于不方便输出的字符采用转义
五、boolean
boolean是逻辑运算类型;
赋值只有true或者false;
经常用于存储关系运算的结果值。
int age=18;
boolean isChild=age>16;
System.out.println(isChild);//true;
基本类型间的转换:
1、基本类型转换
自动类型转换:小类型--大类型
可以自动转换的,如下图:
强制类型转换 :大类型--小类型
byte,short,char这三种不能进行相互转换
需要转换符:格式:(需要转化的类型)变量
注意:这样转化可能精度丢失或者溢出
2、强制转换时的精度丢失和溢出
int a=100;
int b=200;
long c=a+b;
System.out.println(c);
long l1=1024l;
int i=(int)l1;
System.out.println(i);
long l=1024L*1024*4*1024;
int j=(int)l;
System.out.println(j);
double pi=3.1415193084094;
float f=(float)pi;
System.out.println(f);
精度丢失:转化后存储的小数位不是原来的小数位
3、数值运算时的自动转换
多种基本类型参与的表达式运算中,运算结果会自动向较大类型转换
//3.多种基本类型参与运算会向较大类型转换
long l3 = 123*456*789L;//int*int*long 向long转化
double d = 500-599.0;//-99.0
double persent2 = 80/100.0;//0.8
以上是 java的基本类型和类型转化 的全部内容, 来源链接: utcz.com/z/394858.html