• 数据类型与运算符-java


    数据类型与运算符

    1、变量和类型

    1.1、整形变量

    基本语法格式:

    int 变量名 = 初始值;
    
    • 1

    代码示例:

    int num = 10 //定义一个整型变量
    System.out.println(num);
    
    • 1
    • 2

    注意:
    1)java中,一个int变量占4个字节,和操作系统没有直接关系。
    (8个bit为一个字节Byte,1KB = 1024 Byte)
    2)4 个字节表示的数据范围是 -2^31 -> 2^31-1,也就大概是 -21亿 到 +21亿

    1.2长整型变量

    基本语法格式:

    long 变量名 = 初始值;
    
    • 1

    代码示例:

    long num = 10L; //定义一个长整型变量,初始值也可以写10l(小写L不是数字1)
    System.out.println(num);
    
    • 1
    • 2

    注意:
    1)使用 10 初始化也可以,10 的类型是 int,10L 的类型是 long,使用 10L或者 10l更好一些.
    2)Java 中 long 类型占 8 个字节,表示的数据范围 -2^63 -> 2^63-1

    System.out.println(Long.MAX_VALUE);
    System.out.println(Long.MIN_VALUE);
        
    // 运行结果
    9223372036854775807
    -9223372036854775808
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    1.3、双精度浮点型变量

    基本语法格式:

    double 变量名 = 初始值;
    
    • 1

    代码示例:

    double num = 1.0;
    System.out.println(num);
    
    • 1
    • 2

    int除以int的值仍然是int

    int a = 1; 
    int b = 2; 
    System.out.println(a / b); 
    // 执行结果
    0 
    
    • 1
    • 2
    • 3
    • 4
    • 5
    double a = 1.0; 
    double b = 2.0; 
    System.out.println(a / b); 
    // 执行结果
    0.5 
    
    • 1
    • 2
    • 3
    • 4
    • 5

    1.4、单精度浮点型变量

    基本语法格式:

    float 变量名 = 初始值;
    
    • 1

    代码示例:

    float num = 1.0f;//F也可
    System.out.println(num);
    
    • 1
    • 2

    float 类型在 Java 中占四个字节, 同样遵守 IEEE 754 标准. 由于表示的数据精度范围较小, 一般在工程上用到浮点数都
    优先考虑 double, 不太推荐使用 float

    1.5、字符类型变量

    基本语法格式:

    char 变量名 = 初始值;
    
    • 1

    代码示例:

    char ch = 'A';
    
    • 1

    1.6、字节类型变量

    基本语法格式:

    byte 变量名 = 初始值;
    
    • 1

    代码示例:

    byte value = 0 ;
    System.out.println(value);
    
    • 1
    • 2

    1)字节类型表示的也是整数. 只占一个字节, 表示范围较小 ( -128 -> +127 )
    2)字节类型和字符类型互不相干

    1.7、短整型变量

    基本语法格式:

    short 变量名 = 初始值;
    
    • 1

    代码示例:

    short value = 0 ;
    System.out.println(value);
    
    • 1
    • 2

    short 占用 2 个字节, 表示的数据范围是 -32768 -> +32767,这个表示范围比较小, 一般不推荐使用

    1.8、布尔类型变量

    太累了,,,随便写点总结吧。。。

    2、小结

    1、Java 的 boolean 类型和 int 不能相互转换, 不存在 1 表示 true,0 表示 false 这样的用法

    2、String 不是基本类型,而是引用类型

    3、不同数字类型的变量之间赋值,表示范围更小的类型能隐式转换成范围较大的类型,反之则不行(int a = 10; long b = 20;
    a = b; // 编译出错, 提示可能会损失精度. b = a;//编译通过)

    4、使用 (类型) 的方式可以将 double 类型强制转成 int。但是强制类型转换可能会导致精度丢失,如赋值之后, 10.5 就变成 10 了, 小数点后面的部分被忽略。强制类型转换不是一定能成功,互不相干的类型之间无法强转。

    5、对于 short, byte 这种比 4 个字节小的类型,会先提升成 4 个字节的 int ,再运算。

    6、如果不取自增运算的表达式的返回值,则前置自增和后置自增没有区别;如果取表达式的返回值,则前置自增的返回值是自增之后的值,后置自增的返回值是自增之前的值。

    7、短路求值: 对于 &&,如果左侧表达式值为 false, 则表达式的整体的值一定是 false, 无需计算右侧表达式;对于 ||,如果左侧表达式值为 true, 则表达式的整体的值一定是 true, 无需计算右侧表达式(& 和 | 如果操作数为 boolean 的时候, 也表示逻辑运算。但是和 && 以及 || 相比,它们不支持短路求值)

    8、移位运算:左移 1 位 <<1 , 相当于原数字 * 2,左移 N 位, 相当于原数字 * 2 的N次方;
    右移 1 位 >>1 , 相当于原数字 / 2,右移 N 位,相当于原数字 / 2 的N次方。

    9、三目运算符:表达式1 ? 表达式2:表达式3(当表达式1 的值为 true 时,整个表达式的值为表达式2的值;当表达式1的值为 false 时,整个表达式的值为 表达式3的值)
    在这里插入图片描述

  • 相关阅读:
    图论第2天----第1020题、第130题
    NestJS学习:控制器
    你与年薪百万的项目经理,可能就差一个字母
    智引未来,利尔达成功入选首批“5G应用解决方案供应商推荐名录”名单
    使用git实战上传项目
    C语言二维数组定义、赋值、按要求遍历操作、输出以及函数调用
    学习MySQL-第五章
    【数组】灯泡开关 Ⅱ
    笙默考试管理系统-MyExamTest----codemirror(29)
    记录前端通过XShell和xftp发布版本
  • 原文地址:https://blog.csdn.net/qq_42821568/article/details/133969428