java数值类型

本文详细介绍了Java中的基本数据类型,包括数值类型的位宽,并深入解释了计算机中正数和负数的二进制表示方法。此外,还探讨了Java中的位运算符及其使用方法。

一、java基本类型

byte、short、int、long、boolean、char、float、double、

 

其中数值类型:

byte     8位

short    16位

int        32位

long     64位

 

二、计算机二进制表示:

正数:

 

例如:byte i = 4。 

用二进制表示(8位):0000 0100

 

 

 

负数:正数的补码

 

例如:byte i = -4

用二进制表示:

1,4 的二进制是0000 0100

2,0000 0100的反码是 1111 1011

3,1111 1011 加1是1111 1100

 

三、位运算

 

 

<< 左移

>> 带符号右移

>>>无符号右移

 

例如 x >> y

x只能是byte short chart int long

y只能是int

 

1)如果x是byte, short, char类型, 则将x提升为int(就是转换成32位的表示,这里并不是简单的前面加0,而是符号位填充)。

 

                所以 x >> y的结果是个int类型。

 

2)如果x是byte, short, char, int类型, 则y被重新赋值(过程是:取y的补码的低5位再转成十进制的int值,相当对n取32模: n=n%32)。

 

         例如>>33  相当于 >>1。

 

3)如果x是long型, 则y被重新赋值(过程是:取y的补码的低6位再转成十进制的int值,相当对n取64模: n=n%64)。

         例如>>65  相当于 >>1。

 

 

### Java 数值类型概述 Java 定义了几种用于表示不同种类数值的基本数据类型。这些类型可以分为两大类别:整数类型和浮点数类型。 #### 整数类型 Java 提供四种不同的整数类型来存储不带小数部分的数字,每一种都有其特定的取值范围: - `byte`:占用1字节内存空间,适用于较小规模的数据处理场景[^2]。 - `short`:占用2字节内存空间,在某些情况下可作为更节省资源的选择。 - `int`:最常用的整数类型,通常用来保存常规大小的整数值,占据4字节的空间。 - `long`:对于非常大或非常小的整数值,则会采用此8字节长度的数据类型。 #### 浮点数类型 当程序中涉及到带有小数位的操作时,就需要用到浮点数类型Java 中有两种浮点数类型可供选择: - `float`:单精度浮点数,适合大多数需要简单精确度的应用场合,它占据了4个字节的位置。 - `double`:双精度浮点数提供了更高的准确性以及更大的数值范围,因此被广泛应用于科学计算等领域,该类型占用了8个字节的记忆体空间。 除了上述提到的基础数值类型之外,还有两种特殊的类型值得注意——字符型(`char`)与布尔型(`boolean`)。不过这两者并不属于传统意义上的“数值”,而是各自具有独特的用途。 ```java // 示例代码展示如何声明并初始化各种数值类型的变量 public class NumericTypesDemo { public static void main(String[] args) { byte myByte = 10; short myShort = 32767; int myInt = 2_147_483_647; // 使用下划线提高可读性 long myLong = 9_223_372_036_854_775_807L; float myFloat = 3.14f; double myDouble = 3.141592653589793; char myChar = 'A'; boolean isTrue = true; System.out.println("byte: " + myByte); System.out.println("short: " + myShort); System.out.println("int: " + myInt); System.out.println("long: " + myLong); System.out.println("float: " + myFloat); System.out.println("double: " + myDouble); System.out.println("char: " + myChar); System.out.println("boolean: " + isTrue); } } ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值