Java 기본 데이터 유형: 두 가지 주요 범주
내장 데이터 유형
참조 데이터 유형
Java 유형 변환
자동 유형 변환
강제
Java 상수
1. 내장 데이터 유형
Java 언어는 8가지 기본 유형을 제공합니다. 6개의 숫자 유형(4개의 정수, 2개의 부동 소수점 유형), 문자 유형 및 부울 유형.
숫자형 - 정수형 바이트:
바이트 데이터 유형은 2의 보수로 표현되는 8비트 부호 있는 정수입니다.
최소값은 -128입니다. (-2^7);
최대값은 127(2^7-1)입니다.
기본값은 0입니다.
바이트 유형은 공간을 차지하기 때문에 주로 정수를 대체하여 공간을 절약하는 데 사용됩니다. 바이트 변수 기준 int 유형의 1/4만
예: 바이트 a = 100, 바이트 b = -50.
숫자형 - 정수형 단축:
Short 데이터 유형은 16비트 부호 있는 2의 보수 정수입니다.
최소값은 -32768(-2^15)입니다.
최대값은 32767(2^15 - 1)입니다.
예: 짧은 s = 1000, 짧은 r = -20000.
int 데이터 유형은 32비트 부호 있는 2의 보수 정수 표현입니다.숫자형 - 정수형 int:
최소값은 -2,147,483,648(-2^31)입니다.
최대값은 2,147,483,647(2)입니다. ^31 - 1);
일반적으로 정수 변수는 int 유형으로 기본 설정됩니다.
long:long 데이터 유형은 2의 보수로 표현되는 64비트 부호 있는 정수입니다. 🎜>
최대값은 9,223,372,036입니다. ,8 54,775,807 (2^63 -1);
이 유형은 주로 큰 정수를 비교해야 하는 시스템에 사용됩니다. 🎜>
기본값은 0L입니다.
예: long a = 100000L, Long b = -200000L.
float:
float 데이터 유형은 단정밀도, 32비트, IEEE 754 호환 부동 소수점 숫자입니다. float는 큰 부동 소수점 배열을 저장할 때 메모리 공간을 절약할 수 있습니다.
기본값은 0.0f입니다. ;
부동 소수점 숫자는 통화와 같은 정확한 값을 나타내는 데 사용할 수 없습니다. 🎜>예: float f1 = 234.5f.
숫자 유형 - 부동 소수점 유형 double:
이중 데이터 유형은 배정도, 64비트, IEEE 754 호환 부동 소수점 숫자입니다.
부동 소수점 숫자의 기본 유형은
또한 double 유형은 통화와 같은 정확한 값을 나타낼 수 없습니다. 🎜>
기본값은 0.0d입니다.
예: double d1 = 123.4.
부울 --boolean:
부울 데이터 유형은 1비트의 정보를 나타냅니다.
에는 true와 false의 두 가지 값만 있습니다. ;
이 유형은 참/거짓 상황을 기록하는 플래그로만 사용됩니다. 🎜>기본값은 false입니다.
예: 부울 1 = true입니다.
char 유형은 단일 16비트 유니코드 문자입니다.
최소값은 다음과 같습니다. 'u0000'(즉, 0);
최대값은 'uffff'(즉, 65,535)입니다. >
char 데이터 유형은 모든 문자를 저장할 수 있습니다.예: char 문자 = 'A'.
public class PrimitiveTypeTest { public static void main(String[] args) { // byte System.out.println("基本类型:byte 二进制位数:" + Byte.SIZE); System.out.println("包装类:java.lang.Byte"); System.out.println("最小值:Byte.MIN_VALUE=" + Byte.MIN_VALUE); System.out.println("最大值:Byte.MAX_VALUE=" + Byte.MAX_VALUE); System.out.println(); // short System.out.println("基本类型:short 二进制位数:" + Short.SIZE); System.out.println("包装类:java.lang.Short"); System.out.println("最小值:Short.MIN_VALUE=" + Short.MIN_VALUE); System.out.println("最大值:Short.MAX_VALUE=" + Short.MAX_VALUE); System.out.println(); // int System.out.println("基本类型:int 二进制位数:" + Integer.SIZE); System.out.println("包装类:java.lang.Integer"); System.out.println("最小值:Integer.MIN_VALUE=" + Integer.MIN_VALUE); System.out.println("最大值:Integer.MAX_VALUE=" + Integer.MAX_VALUE); System.out.println(); // long System.out.println("基本类型:long 二进制位数:" + Long.SIZE); System.out.println("包装类:java.lang.Long"); System.out.println("最小值:Long.MIN_VALUE=" + Long.MIN_VALUE); System.out.println("最大值:Long.MAX_VALUE=" + Long.MAX_VALUE); System.out.println(); // float System.out.println("基本类型:float 二进制位数:" + Float.SIZE); System.out.println("包装类:java.lang.Float"); System.out.println("最小值:Float.MIN_VALUE=" + Float.MIN_VALUE); System.out.println("最大值:Float.MAX_VALUE=" + Float.MAX_VALUE); System.out.println(); // double System.out.println("基本类型:double 二进制位数:" + Double.SIZE); System.out.println("包装类:java.lang.Double"); System.out.println("最小值:Double.MIN_VALUE=" + Double.MIN_VALUE); System.out.println("最大值:Double.MAX_VALUE=" + Double.MAX_VALUE); System.out.println(); // char System.out.println("基本类型:char 二进制位数:" + Character.SIZE); System.out.println("包装类:java.lang.Character"); // 以数值形式而不是字符形式将Character.MIN_VALUE输出到控制台 System.out.println("最小值:Character.MIN_VALUE=" + (int) Character.MIN_VALUE); // 以数值形式而不是字符形式将Character.MAX_VALUE输出到控制台 System.out.println("最大值:Character.MAX_VALUE=" + (int) Character.MAX_VALUE); } }로그인 후 복사
위 코드를 컴파일한 결과는 다음과 같습니다.
基本类型:byte 二进制位数:8 包装类:java.lang.Byte 最小值:Byte.MIN_VALUE=-128 最大值:Byte.MAX_VALUE=127 基本类型:short 二进制位数:16 包装类:java.lang.Short 最小值:Short.MIN_VALUE=-32768 最大值:Short.MAX_VALUE=32767 基本类型:int 二进制位数:32 包装类:java.lang.Integer 最小值:Integer.MIN_VALUE=-2147483648 最大值:Integer.MAX_VALUE=2147483647 基本类型:long 二进制位数:64 包装类:java.lang.Long 最小值:Long.MIN_VALUE=-9223372036854775808 最大值:Long.MAX_VALUE=9223372036854775807 基本类型:float 二进制位数:32 包装类:java.lang.Float 最小值:Float.MIN_VALUE=1.4E-45 最大值:Float.MAX_VALUE=3.4028235E38 基本类型:double 二进制位数:64 包装类:java.lang.Double 最小值:Double.MIN_VALUE=4.9E-324 最大值:Double.MAX_VALUE=1.7976931348623157E308 基本类型:char 二进制位数:16 包装类:java.lang.Character 最小值:Character.MIN_VALUE=0 最大值:Character.MAX_VALUE=65535로그인 후 복사
Float和Double的最小值和最大值都是以科学记数法的形式输出的,结尾的"E+数字"表示E之前的数字要乘以10的多少次方。比如3.14E3就是3.14 × 103 =3140,3.14E-3 就是 3.14 x 10-3 =0.00314。
实际上,JAVA中还存在另外一种基本类型 void,它也有对应的包装类 java.lang.Void,不过我们无法直接对它们进行操作。
二、引用类型
在Java中,引用类型的变量非常类似于C/C++的指针。引用类型指向一个对象,指向对象的变量是引用变量。这些变量在声明时被指定为一个特定的类型,比如Employee、Pubby等。变量一旦声明后,类型就不能被改变了。
需要注意:
对象、数组都是引用数据类型。
所有引用类型的默认值都是null。
一个引用变量可以用来引用与任何与之兼容的类型。
例子:Site site = new Site("Runoob")。
Java 语言是一种强类型的语言。强类型的语言有以下几个要求:
变量或常量必须有类型:要求声明变量或常量时必须声明类型,而且只能在声明以后才能使用。
赋值时类型必须一致:值的类型必须和变量或常量的类型完全一致。
运算时类型必须一致:参与运算的数据类型必须一致才能运算。
但是在实际的使用中,经常需要在不同类型的值之间进行操作,这就需要一种新的语法来适应这种需要,这个语法就是数据类型转换。
在数值处理这部分,计算机和现实的逻辑不太一样,对于现实来说,1和 1.0 没有什么区别,但是对于计算机来说,1 是整数类型,而 1.0 是小数类型,其在内存中的存储方式以及占用的空间都不一样,所以类型转换在计算机内部是必须的。
Java 语言中的数据类型转换有两种:
自动类型转换:编译器自动完成类型转换,不需要在程序中编写代码。
强制类型转换:强制编译器进行类型转换,必须在程序中编写代码。
由于基本数据类型中 boolean 类型不是数字型,所以基本数据类型的转换是出了 boolean 类型以外的其它 7 种类型之间的转换。下面来具体介绍两种类型转换的规则、适用场合以及使用时需要注意的问题。
一、自动类型转换
自动类型转换,也称隐式类型(隐含类型)转换,是指不需要书写代码,由系统自动完成的类型转换。由于实际开发中这样的类型转换很多,所以 Java 语言在设计时,没有为该操作设计语法,而是由 JVM 自动完成。 当范围低的基本类型和范围高的基本类型做运算时,范围低的就会自动转换为高范围的类型,还有,当子类赋给父类变量时,也属于自动类型转换。而一般强制类型转换就是反过来说,也是他们的区别
1. 整数的默认类型时int
2. 浮点型不存在这种情况,因为在定义float类型时必须在数字后面跟上F或者f
转换规则:从存储范围小的类型到存储范围大的类型。
具体规则为:byte→short(char)→int→long→float→double所有,整型、实型(常量)、字符型数据可以混合运算。运算中,不同类型的数据先转化为同一类型,然后进行运算。转换从 --> 低级到高级。
byte,short,char—> int —> long—> float —> double로그인 후 복사
也就是说 byte 类型的变量可以自动转换为 short 类型,示例代码:
byte b = 10;로그인 후 복사
short sh = b;这里在赋值时,JVM 首先将 b 的值转换为 short 类型,然后再赋值给 sh。
在类型转换时可以跳跃。示例代码:
byte b1 = 100;int n = b1;로그인 후 복사
注意问题 : 在整数之间进行类型转换时,数值不发生改变,而将整数类型,特别是比较大的整数类型转换成小数类型时,由于存储方式不同,有可能存在数据精度的损失。
int i =128; byte b = (byte)i;
因为byte类型时8位,最大值为127,所以当强制转换为int类型值128时候就会导致溢出。
——浮点数到整数的转换是通过舍弃小数得到,而不是四舍五入,例如:
(int)23.7 == 23; (int)-45.89f == -45
必须满足转换前的数据类型的位数要低于转换后的数据类型,例如: short数据类型的位数为16位,就可以自动转换位数为32的int类型,同样float数据类型的位数为32,可以自动转换为64位的double类型。
数据类型转换必须满足如下规则:
1. 不能对boolean类型进行类型转换。
2. 不能把对象类型转换成不相关类的对象。
3. 在把容量大的类型转换为容量小的类型时必须使用强制类型转换。
4. 转换过程中可能导致溢出或损失精度,例如:
public class ZiDongLeiZhuan{ public static void main(String[] args){ char cao1='a';//定义一个char类型 int it1 = cao1;//char自动类型转换为int System.out.println("char自动类型转换为int后的值等于"+it1); char cao2 = 'A';//定义一个char类型 int it2 = cao2+10;//char 类型和 int 类型计算 System.out.println("char类型和int计算后的值等于"+it2); } }로그인 후 복사
运行结果为:
char自动类型转换为int后的值等于 97 char类型和int计算后的值等于 75로그인 후 복사
解析:
cao1 的值为字符'a', 查 ascii 码表可知对应的int类型值为 97( 文章最后会提供 ASCII 表 )
那么字符 cao2 的'A' 对应值为65,所以it2=65+10=75。
二、强制类型转换
强制类型转换,也称显式类型转换,是指必须书写代码才能完成的类型转换。该类类型转换很可能存在精度的损失,所以必须书写相应的代码,并且能够忍受该种损失时才进行该类型的转换。
1. 条件是转换的数据类型必须是兼容的。
2. 格式:(type)value type是要强制类型转换后的数据类型
实例:
public class QiangZhiZhuanHuan{ public static void main(String[] args){ int i1 = 123456; byte b = (byte)i1;//强制类型转换为byte System.out.println("int强制类型转换为byte后的值等于"+b); } }
运行结果:
int强制类型转换为byte后的值等于 12356
转换规则:从存储范围大的类型到存储范围小的类型。
具体规则为:double→float→long→int→short(char)→byte
语法格式为:(转换到的类型)需要转换的值
示例代码:
double d = 3.10;int n = (int)d;로그인 후 복사
这里将 double 类型的变量 d 强制转换成 int 类型,然后赋值给变量 n。需要说明的是小数强制转换为整数,采用的是“去 1 法”,也就是无条件的舍弃小数点的所有数字,则以上转换出的结果是 3。整数强制转换为整数时取数字的低位,例如 int 类型的变量转换为 byte 类型时,则只去 int 类型的低 8 位(也就是最后一个字节)的值。
示例代码:
int n = 123;byte b = (byte)n;int m = 1234;byte b1 = (byte)m;로그인 후 복사
则 b 的值还是 123,而 b1 的值为-46。
b1 的计算方法如下:m 的值转换为二进制是10011010010,取该数字低8位的值作为b1的值,则b1的二进制值是11010010,按照机器数的规定,最高位是符号位,1 代表负数,在计算机中负数存储的是补码,则该负数的原码是 10101110,该值就是十进制的-46。
注意问题:强制类型转换通常都会存储精度的损失,所以使用时需要谨慎。
常量在程序运行时,不会被修改的量。
在 Java 中使用 final 关键字来修饰常量,声明方式和变量类似:
final double PI = 3.1415927;로그인 후 복사虽然常量名也可以用小写,但为了便于识别,通常使用大写字母表示常量。
字面量可以赋给任何内置类型的变量。例如:
byte a = 68;로그인 후 복사char a = 'A'로그인 후 복사
byte、int、long、和short都可以用十进制、16进制以及8进制的方式来表示。
当使用常量的时候,前缀0表示8进制,而前缀0x代表16进制。例如:
int decimal = 100;로그인 후 복사int octal = 0144;로그인 후 복사int hexa = 0x64;로그인 후 복사
和其他语言一样,Java的字符串常量也是包含在两个引号之间的字符序列。下面是字符串型字面量的例子:
"Hello World" "two\nlines" "\"This is in quotes\""로그인 후 복사
字符串常量和字符常量都可以包含任何Unicode字符。例如:
char a = '\u0001'; String a = "\u0001";로그인 후 복사
Java语言支持一些特殊的转义字符序列:
기호 | 문자 의미 |
---|---|
n | 라인피드(0x0a) |
r | 입력(0x0d ) |
f | 폼 피드(0x0c) |
b | 백스페이스(0x08) |
s | 스페이스(0x20) |
t | 탭 |
" | 큰따옴표 |
' | 작은따옴표 |
\ | 백슬래시 |
ddd | 8진수 문자(ddd) |
uxxxx | 16진수 유니코드 문자(xxxx) |
위 내용은 JAVA Pit 튜토리얼 2장 기본 자료형 내용입니다. , 더 많은 관련 내용을 보려면 PHP 중국어 웹사이트(www.php.cn)를 주목하세요!