文章目录
前言
本文主要介绍java语言中的基本数据类型
1、变量
在介绍java的数据类型之前,我们先来简单了解一下什么是变量
1.1 什么是变量
变量的概念:
- 内存中的一个存储区域 。
- 该区域的数据可以在同一类型范围内不断变化 。
- 变量是程序中最基本的存储单元,包含变量类型、变量名和存储的值 。
1.2 变量的作用
- 用于在内存中保存数据
使用变量的注意事项:
- 由于java语言是强类型语言,强类型包含两方面的含义:① 所有的变量必须先声明、后使用;② 指定类型的变量只能接受类型与之匹配的值。因此,Java中每个变量必须先声明,后使用。
- 使用变量名来访问这块区域的数据 。
- 变量的作用域:其定义所在的一对{ }内 。
- 变量只有在其作用域内才有效。
1.3 变量的声明与赋值
- 声明变量 :
- 语法:<数据类型> <变量名称>
- 例如:int var;
- 变量的赋值:
- 语法:<变量名称> = <值>
- 例如:var = 10;
- 声明和赋值变量
- 语法: <数据类型> <变量名> = <初始化值>
- 例如:int var = 10;
/**
* 变量的声明与赋值的方式
*/
public void varStatement() {
// 先声明,后赋值
int var1;
var1 = 10;
// 声明的同时并赋值
int var2 = 20;
}
1.4 变量的分类
- 按数据类型分类:
- 基本数据类型:boolean类型和数值类型(char类型可以参与数学运算与转换,因此可以将其归为数值类型)。
- 引用类型:类、接口和数组类型,特殊的null类型(null类型没有名称,空引用(null)是null类型变量唯一的值。空引用(null)可以转换为任何引用类型。空引用(null)只能被转换成引用类型,不能转换成基本类型)
- 按声明位置不同分类:
- 在方法体外,类体内声明的变量称为成员变量。
- 在方法体内部声明的变量称为局部变量。
- 二者在初始化值方面的异同:
同:都有生命周期 异:局部变量除形参外,需显式初始化。
2、基本数据类型
Java语言只包含8种基本数据类型(四类八种)
2.1 整型
说明:
- Java各整数类型有固定的表数范围和字段长度,不受具体OS的影响,以保证java程序的可移植性。
- Java的整型常量默认为 int 型,声明long型常量须后加‘l’或‘L’(推荐)。
- Java程序中变量通常声明为int型,除非不足以表示较大的数,才使用long。
- Java语言中将一个在byte或者short类型的范围内的整数,赋给一个byte或short变量,系统会自动将这个整数当成byte或者short类型来处理。
- Java语言中使用一个超出int类型范围的整数,java不会将这个整数当成long类型来处理。
- Java中整数值有4种表示方式:十进制、二进制、八进制和十六进制,其中二进制的整数以0b或0B开头;八进制的整数以0开头;十六进制的整数以0x或者0X开头,其中10~15分别以a~f(此处的a~f不区分大小写)来表示。
- 计算机底层都是以二进制存在的,整数在计算机中是以补码形式存储(补码计算规则:正数的补码和原码完全相同,负数的补码是其反码加1;反码是对原码按位取反,只是最高位(符号位:0正数,1负数)保持不变)。
注:计算机中的最小存储单位。byte:计算机中基本存储单元
2.2 字符型
字符型通常用于表示单个的字符,字符型值必须使用单引号(’)括起来,Java语言使用16位的Unicode字符集作为编码方式。
字符型变量的三种表现形式:
- 字符常量是用单引号(‘ ’)括起来的单个字符。例如:char c1 = ‘a’; char c2
= ‘中’; char c3 = ‘9’; char=97(输出表示为a,开发中很少见); - Java中还允许使用转义字符‘\’来将其后的字符转变为特殊字符型常量。例如:char c3 = ‘\n’; // '\n’表示换行符。
- 直接使用 Unicode 值来表示字符型常量:‘\uXXXX’。其中,XXXX代表 一个十六进制整数。如:\u000a 表示 \n。
- char类型是可以进行运算的。因为它都对应有Unicode;由于计算机底层保存字符时,实际是保存该字符对应的编号,因此 char类型的值也可直接作为整型值来使用,它相当于一个16位的无符号整数,表数范围是0~65535。
2.3 浮点型
在java中浮点型可以分为:float和double,Java的浮点数遵循IEEE 754标准,采用二进制数据的科学计数法来表示浮点数。
说明:
- 与整数类型类似,Java 浮点类型也有固定的表数范围和字段长度,不受具体操作系统的影响。
- 浮点型的第一位是符号位,剩下的位数才表示指数。
- float:单精度,尾数可以精确到7位有效数字。很多情况下,精度很难满足需求。
double:双精度,精度是float的两倍。通常采用此类型。 - Java 的浮点型常量默认为double型,声明float型常量,须后加‘f’或‘F’。
- Java还提供了三个特殊的浮点数值:正无穷大、负无穷大和非数,用于表示溢出和出错。所有的正无穷大数值都是相等的,所有的负无穷大数值都是相等的;而NaN不与任何数值相等,甚至和NaN都不相等。
浮点型常量有两种表示形式:
- 十进制数形式:如:5.12 512.0 0 .512 (必须有小数点)
- 科学计数法形式:如:5.12e2 512E2 100E-2
注意:浮点型相加减精度容易丢失,通常使用BigDecimal类转换为BigDecimal对象;Java 7引入了一个新功能:程序员可以在数值中使用下画线,不管是整型数值,还是浮点型数值,都可以自由地使用下画线。通过使用下画线分隔,可以更直观地分辨数值中到底包含多少位。
2.4 布尔型
boolean类型的数值只能是true或false,不能用0或者非0来代表。其他基本数据类型的值也不能转换成boolean类型。
说明:
- Java规范并没有强制指定boolean类型的变量所占用的内存空间。虽然boolean类型的变量或值只要1位即可保存,但由于大部分计算机在分配内存时允许分配的最小内存单元是字节(8位),因此bit大部分时候实际上占用8位。
- boolean 类型用来判断逻辑条件,一般用于程序流程控制:if条件控制语句; while循环控制语句; do-while循环控制语句; for循环控制语句。
- boolean类型数据只允许取值true和false,无null;不可以使用0或非 0 的整数替代false和true,这点和C语言不同。
- Java虚拟机中没有任何供boolean值专用的字节码指令,Java语言表达所操作的boolean值,在编译之后都使用java虚拟机中的int数据类型来代替:true用1表示,false 用0表示。———《java虚拟机规范 8》
2.5 使用var定义变量
从Java 10开始支持使用var定义局部变量,目的是为了简化局部变量的声明
说明:
- var相当于一个动态类型,使用var定义的局部变量的类型由编译器自动推断—定义变量时分配了什么类型的初始值,那该变量就是什么类型。
- Java的var与JavaScript的var截然不同:Java使用var定义的变量依然有明确的类型—为局部变量指定初始值时,该变量的类型就确定下来了。
- 使用var定义局部变量时,必须在定义局部变量的同时指定初始值,否则编译器无法推断该变量的类型。
- Java使用var定义局部变量只是形式的改变,这些变量依然有明确的类型。
- 使用var定义局部变量,其优点在于:编码更简洁,不管什么类型的局部变量,直接使用var声明即可;其缺点在于:变量类型的可读性降低了。
2.6 基本类型的类型转换
Java语言所提供的7种数值类型之间可以相互转换,有两种类型转换方式:自动类型转换和强制类型转换
2.6.1 自动类型转换
自动类型转换:系量小的类型自动转换为容量大的数据类型;否则就需要强制转换。
说明:
- 有多种类型的数据混合运算时,系统首先自动将所有数据转换成容量最大的那种数据类型,然后再进行计算
- byte,short,char之间不会相互转换,他们三者在计算时首先转换为int类型。
- boolean类型不能与其它数据类型运算。
- 当把任何基本数据类型的值和字符串(String)进行连接运算时(+),基本数据类型的值将自动转化为字符串(String)类型。
2.6.2 强制类型转换
强制类型转换:自动类型转换的逆过程,将容量大的数据类型转换为容量小的数据类型。使用时要加上强制转换符:(),但可能造成精度降低或溢出,格外要注意。
说明:
- 字符串不能直接转换为基本类型,但通过基本类型对应的包装类则可以实现把字符串转换成基本类型。如:String a = “43”; int i = Integer.parseInt(a);
- boolean类型不可以转换为其它的数据类型。
2.7 直接量
直接量(literal value):在程序中通过源代码直接给出的值。
Java支持如下8种类型的直接量:
- int类型的直接量:在程序中直接给出的整型数值,可分为二进制、十进制、八进制和十六进制4种,其中二进制需要以0B或0b开头,八进制需要以0开头,十六进制需要以0x或0X开头。
- long类型的直接量:在整型数值后添加l或L后就变成了long类型的直接量。
- float类型的直接量:在一个浮点数后添加f或F就变成了float类型的直接量,这个浮点数可以是标准小数形式,也可以是科学计数法形式。
- double类型的直接量:直接给出一个标准小数形式或者科学计数法形式的浮点数就是double类型的直接量。
- boolean类型的直接量:这个类型的直接量只有true和false。
- char类型的直接量:char类型的直接量有三种形式,分别是用单引号括起来的字符、转义字符和Unicode值表示的字符。
- String类型的直接量:一个用双引号括起来的字符序列就是String类型的直接量。当程序第一次使用某个字符串直接量时,Java会使用常量池(constant pool)来缓存该字符串直接量,如果程序后面的部分需要用到该字符串直接量时,Java会直接使用常量池中的字符串直接量
- null类型的直接量:这个类型的直接量只有一个值,即null。它可以赋给任何引用类型的变量,用以表示这个引用类型变量中保存的地址为空,即还未指向任何有效对象。
示例代码
@Test
public void basicDataTypeTest() {
//以下变量的赋值都是采用直接量
/*
* 整型
*/
// byte
byte by1 = 12;//正确
// byte by2 = 128;//错误:Type mismatch: cannot convert from int to byte
//short
short short1 = 32767;
// short short2 = 32768;//Type mismatch: cannot convert from int to short
//int
int int1 =32767;
// int int2 =999999999999;//The literal 999999999999 of type int is out of range
//long
//long类型变量声明必须在数值后使用L后缀,强制使用long类型
// long long1=999999999999;//Type mismatch: cannot convert from int to short
long long2=999999999999L;
//-------------------------------
//二进制整型数据
int bin =0b1101001;//105
System.out.println("bin-八进制整型数据:"+bin);
//八进制整型数据
int octal=0110101;//36929
System.out.println("octal-八进制整型数据:"+octal);
//十六进制整型数据
int hex=0xaf;//175
System.out.println("hex-八进制整型数据:"+hex);
/*
* 字符型
*/
char a='a';
char chinese='中';
char ch='\u56fd';
char en='\r';
System.out.println("a--:"+a+" en--:"+en+" chinese--:"+chinese+" ch--:"+ch);
/*
* 浮点型
*/
//float
// float f1=2.0;//Type mismatch: cannot convert from double to float
float f2=2.0f;
//double
double d1=2.0;
//正无穷大相等
System.out.println(6.0/0==Double.POSITIVE_INFINITY);//true
//负无穷大相等
System.out.println(-6.0/0==Double.NEGATIVE_INFINITY);//true
//非数不相等
System.out.println(0.0/0.0==Double.NaN);//false
/*
* 布尔型
*/
boolean b1=false;
boolean b2=true;
/*
* 自动类型转化和强制类型转换
*/
//自动类型转换
byte a1=2;
int a2=a1;
//强制类型转换
double do1=34.00;
int num1=(int)do1;
//=================================
/*
* 使用var定义变量
*/
var num=20;//num被赋值为20,因此num的类型为int
// num=1.6;//Type mismatch: cannot convert from double to int
// var c;//Cannot use 'var' on variable without initializer
var str="5";//str被赋值为字符串5,因此str的类型为String
// str=5;//ype mismatch: cannot convert from int to String
}