li

XXXXX

 

java的基本类型和类型转化

1、八种基本数据类型:

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

 

posted on 2022-03-10 16:06  LXXXXxZz  阅读(96)  评论(0编辑  收藏  举报

导航