Java基本数据类型

1.Java基本数据类型有哪些

2.Java基本数据类型特点

3.Java基本数据类型封装器类

整型:byte--->Byte、short--->Short、int--->Integer、long--->Long

浮点型:float--->Float、double--->Double

字符型:char--->Character

布尔型:boolean--->Boolean

4.什么是内存

程序中所有的数据,在运行起来之后,保存在计算机的内存中

计算机存储数据基本单位:bit:二进制位 10 => 1010,使用四个比特位存储

                                        byte:字节,计算机保存的数据,以字节为单位

                                        1byte = 8bit

                                     

5.程序中的两种类型数值

变量:定义之后,数值可以改变的内容,称之为变量,能变的只有数值内容,数据类型无法改变!

常量:定义之后,数值无法改变,称之为常量

基本语法 变量名称 = 初始值

例:int a = 8; 该代码定义了一个整型变量,变量名称(标识符)为a,能变的时a保存的数值,不能改变a变量的类型。

//定义了一个整型变量,变量名称(标识符)为a
        int a = 10;
        //定义了一个浮点型变量b
        double b = 3.1415;
        //定义了一个字符型变量c
        char c = 'a';
        //定义了一个布尔型变量d
        boolean d = true;

        System.out.println(a);//10
        System.out.println(b);//3.1415
        System.out.println(c);//a
        System.out.println(d);//true
        //a是变量,因此a中保存的数值可以修改,但必须要在整型的保存范围之内
        
        a = 200;
        System.out.println(a);//200

在一行之中,可以定义多个相同类型数据变量。

//在一行中定义多个相同类型的变量
int a = 10,b = 20,c;//abc都是int类型的变量

6.数值型变量

整型变量 int 无论什么操作系统,什么版本的JVM,int一律都是4字节

public class test1 {
    public static void main(String[] args) {
       //方法一,定义整型变量时赋予初值
        int a = 10;
        //方法二,定义时不赋值,在这个变量使用之前必须赋值
        int b;
        
        b = 20;
        //输出之前赋值
        System.out.println(b);
    }
}

7.观察数据类型的默认值:数据类型必须在类中定义变量,才具有默认值

public class IntTest {
    //在类中定义的变量存在默认值,成员变量
    //默认值就是该数据类型对应的默认值,int默认值就是0
    //在方法中定义的局部变量必须复制后再使用,不存在默认值
    //类中定义的变量值存在默认值,默认值就是不同数据类型对应的值
    int c;//类中定义的变量
    public static void main(String[] args) {
        IntTest intTest = new IntTest();
        //int的默认值为0
        System.out.println(intTest.c);
    }
}

8.观察数据溢出问题

 当小的数据类型存放不下正确的数值我们就需要更换更大的数据类型 int < long

9.字面量

直接写出来的数值就叫做字面量,字面量也存在数据类型(字面量属于常量)

10 ->整型字面量,默认为int型

10.1 -> 浮点型字面量,默认为double类型

'a' -> 字符型字面量,默认为char型

true -> 布尔型字面量,默认为boolean类型

'abc' -> 字符串字面量,String类型

10.类型转换与类型提升

小类型转换为大类型自动转换,大类型转换为小类型需要强制类型转换,有精度丢失的问题

float b = 10.1//是否正确? 错误

10.1为double类型,8字节 比float大 需要强制转换

如:float b = (float)10.1;

       float b = 10.1F

关于int、byte、char之间转换的问题 

计算机存储数据时默认采用4字节存储,所有小于4字节的数据类型(byte short char),隐式提升为int之后进行存储(boolean除外)

当把整形字面量赋给byte变量时,若byte保存范围直接赋给byte b = 120;若超出了byte的保存范围,必须进行强转,有精度丢失的问题byte b = (byte)130;

 char和int之间的转换

2字节、4字节

 

类型提升,当不同数据类型进行运算时,自动会将小类型提升为大类型进行运算!

int + long

 

 判断:对于基本类型来说,所有类型之间都可以进行转换 ->错误

能互相转换的数据类型之间才能强转或者提升

boolean与任何类型毫无关系,无法强转也无法提升!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值