数据类型与运算符-java

数据类型与运算符

1、变量和类型

1.1、整形变量

基本语法格式:

int 变量名 = 初始值;

代码示例:

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

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

1.2长整型变量

基本语法格式:

long 变量名 = 初始值;

代码示例:

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

注意:
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.3、双精度浮点型变量

基本语法格式:

double 变量名 = 初始值;

代码示例:

double num = 1.0;
System.out.println(num);

int除以int的值仍然是int

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

1.4、单精度浮点型变量

基本语法格式:

float 变量名 = 初始值;

代码示例:

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

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

1.5、字符类型变量

基本语法格式:

char 变量名 = 初始值;

代码示例:

char ch = 'A';

1.6、字节类型变量

基本语法格式:

byte 变量名 = 初始值;

代码示例:

byte value = 0 ;
System.out.println(value);

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

1.7、短整型变量

基本语法格式:

short 变量名 = 初始值;

代码示例:

short value = 0 ;
System.out.println(value);

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的值)
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值