Java基本数据类型

Java语言是强类型语言:对数据类型的要求很严格。声明是什么类型的变量,就要存储什么类型的数值。

一、数据类型的分类

Java数据类型可分为两大类:

  • 基本数据类型:byte、short、int、long、float、double、char、boolean
  • 引用类型:类、接口、数组、枚举
Java基本数据类型插图

二、基本数据类型

1、八种基本数据类型

基本数据类型,也叫原始数据类型。在Java中,有八种原始数据类型:布尔型,字符型,字节型,短型,整型,长型,浮点型和双精度。基本数据类型有以下4类8种:

  • 整数型—- byte(字节), short(短整型), int(整型), long(长整型)用于存储整数。
  • 浮点型—- float(单精度浮点型), double(双精度浮点型)用于存储小数。
  • 字符型—- char用于存储字符
  • 布尔型—- boolean用于存储true和false,表示对和错。

2、基本数据类型的存储

Java中所有的基本数据类型都有固定的存储范围和所占内存空间的大小,而不受具体操作系统的影响,以保证Java程序的可移植性 。

3、整数型

Java基本数据类型插图2
  • byte:它可以容纳-128到127之间的整数。通常用于节省内存,并且可以确定数字在字节数据类型指定的限制内。
public class  Demo04datatype {

   public static void main(String[] args) {
     //定义byte类型的变量
     byte num = 10;
     System.out.println(num);
     //存储的大小如果超过了byte的取值范围,就会报错了
     byte num2 = 129;
     System.out.println(num2);
   }
 }

定义变量进行赋值的时候,不能超出该种数据类型的取值范围:

Java基本数据类型插图4
  • short:短整型,就大小而言,它大于字节,并且小于整数。其范围是-32768到32767。
  • int:当short不足以容纳数字时使用,它的取值范围更大,int类型也是平时使用最多的一种整型类型。它也是整数类型中的默认类型。
  • long:当int的大小不足以容纳该值时使用,它的范围比int数据类型的范围更广,范围从-9,223,372,036,854,775,808到9,223,372,036,854,775,807。

要声明long型可以加”l”或者”L”,小写l或者大写L。

public class  Demo04datatype {

   public static void main(String[] args) {
     //1.定义byte类型的变量
     byte num = 10;
     System.out.println(num);
     //存储的大小如果超过了byte的取值范围,就会报错了
     //byte num2 = 129;
     //System.out.println(num2);
 
     //2.short类型的变量,
     short s = 129;//取值范围:-32768~32767,共(65536个数值)
     System.out.println(s);
 
     //3.int类型的变量
     int i = 1314;//取值范围:-2147483648~2147483647
     System.out.println(i);
 
     //4.long类型的变量
     long l1 = 9223372036854775807L;//加L表示该数值是long类型的
     System.out.println(l1);
 
     int age = 19;
     long l2 = 100000000L;
   }
 }

运行结果:

Java基本数据类型插图6

Java语言的整型数值默认为int型,如:int i = 3;
要声明long型可以加‘l’或‘ L’,如:long l = 3L;
注意:在数值超过int的表述范围时(2147483647),需要加上l/L对long赋值

4、浮点型

浮点型所存储的数据,就是平时所说的小数。带精度的。

Java基本数据类型插图8
  • float:单精度浮点数(精度6,7位) 4个字节
  • double:双精度浮点数 (精度15,16位) 8个字节

注意:Java浮点型常量默认为double型,如要声明一个float型,则需在赋值的数字后面加f或F,如: double d = 3.14; float f = 3.14f;

Java浮点类型常量有两种表示形式
十进制数形式,必须含有小数点,例如:
3.14 314.0 0.314
科学记数法形式,如
3.14e2 3.14E2 314E2

注意:float double存储的数据都是近似值。

示例代码:

public class Demo05FloatAndDouble {

   public static void main(String[] args) {
     //1.单精度浮点数:float
     float f = 3.14f;
     System.out.println(f);
 
     //2.双精度浮点数:double
     double d = 1.23;//java中的小数,默认类型是double
     System.out.println(d);
 
     //科学计数法
     double d2 = 2000;//int,隐含了数据类型的自动转换
     System.out.println(d2);
 
     double d3 = 2000.0;//double
     System.out.println(d3);
 
     double d4 = 2E3;//相当于2*10的3次方
     System.out.println(d4);
 
     //1.7E308,相当于1.7乘以10的308次方。17后有307个0
     double d5 = 17000000000000000000000000.0;//double
     System.out.println(d5);
 
     //1.浮点类型:IEEE754标准。
   }
 }

运行结果:

Java基本数据类型插图10

注意:计算机中表示小数使用工业标准IEEE754,所以小数的加减运算,都是带精度的近似数,不一定和口算的结果完全相同。

5、字符型

char型数据用来表示通常意义上“字符”。表示单个的字符,使用单引号引起来的,但本质上是个数值,因为对应的字符编码值。Java字符采用Unicode编码,每个字符占两个字节,因而可用十六进制编码形式表示(Unicode是全球语言统一编码)。

  • 可以通过单个字符直接赋值。
char c1 = 'a';
  • 也可以赋值为一个汉字(汉字也是一个字符,中文字符)
char c2 = '中';
  • 还可以通过编码进行赋值
char c3 = 97;//ASCII美国标准信息交换码,相当于'a'
  • 还可以通过16进制的编码值进行赋值
char c4 = 'u0061';//相当于’a’

ASCII编码表:

示例代码:

public class Demo06Char {

   public static void main(String[] args) {
     //字符类型:char,使用单引号引起来
     char c = 'A';
     System.out.println(c);
 
     //使用编码值进行存储
     char c2 = 65;//65是字符A的编码值
     System.out.println(c2);
 
     //采用unicode编码:16进制赋值
     char c3 = 'u0041';
     System.out.println(c3);
 
     char c4 = '中';
     System.out.println(c4);
     System.out.println((int)c4);//将c4这个字符按照数值打印:其实就是该字符的编码值
 
     char c5 = 20013;
     System.out.println(c5);//中
 
     char c6 = '国';//22269
     System.out.println((int)c6);
 
     char c7 = 22269;
     System.out.println(c7);
   }
 }

转义字符:

Java语言中还允许使用转义字符,来将其后的字符转变为其它的含义。将字符进行转义–>语法上使用 1、将有特殊作用的字符,转为普通的字符,不再起作用 ‘,”, 2、还可以将一些普通的字符,转为有特殊含义的作用 n,t

示例代码:

public class Demo07TranserSign {

   public static void main(String[] args) {
     /*
     转义字符:将字符进行转义-->语法上使用
       1、将有特殊作用的字符,转为普通的字符,不再起作用
         ',",
       2、还可以将一些普通的字符,转为有特殊含义的作用
         n,t
     */ 
     char c = ''';//'
     System.out.println(c);
     char c2 = '"';//"
     System.out.println(c2);
 
     System.out.println("HellonWortld");
     System.out.println("D:Ruby程序咖");//路径
     System.out.println(""HelloWorld"");//打印带双引号的helloworld
   }
 }

6、布尔类型

boolean类型适于逻辑运算,一般用于程序流程控制 boolean类型数据只允许取值true或false,不可以用0或非0的整数替代true和false。

示例代码:

public class Demo08Boolean {

   public static void main(String[] args) {
     //定义一个boolean类型 的变量
     //该类型,只有2个值:true,false
     boolean b1 = true;
     boolean b2 = false;
 
     //"表达式",就是一个式子,数值和一些运算符组成的
     // 3 + 5 -->8
     boolean b3 = 3 > 5;//3 > 5的计算结果:false
     //当给boolean类型变量赋值的时候,
     //可以直接赋值:true,false
     //也可以赋值为一个表达式:该表达式的计算结果是true或者false
 
     System.out.println(b1);
     System.out.println(b2);
     System.out.println(b3);//false
   }
 }

三、基本数据类型的转换

Java语言是一种强类型语言,定义的变量数据类型和赋值的数据类型需要统一。但是允许程序上做一定程度的数据类型转换。分为以下两种:

  • 自动类型转换
  • 强制类型转换

注意:boolean类型不能和其他类型进行转换。

1、自动类型转换

自动类型转换:容量小的类型自动转换成容量大的数据类型。这里的容量是指该数据类型的取值范围。

自动类型转换:数据类型取值范围小的转为取值范围大的
1、byte —> short—>int—>long—>float —>double
2、char—> int
3、byte,short,char三者在计算时会转换成int类型 (了解)
4、int整型常量和字符常量在合理范围内可以直接赋值给 byte、short、int、char (了解)

示例代码:

public class Demo09Convert {

   public static void main(String[] args) {
     //1.自动类型转换:取值范围小的自动转为取值范围大的。
     short s1 = 123;//
     int i1 = s1;//隐含着将s1这个数值由short类型转为int,再赋值给i1这个变量
     System.out.println(s1);
     System.out.println(i1);
 
     byte b1 = 10;
     int i2 = b1;//byte-->int
     System.out.println(i2);
   }
}

2、强制类型转换

强制类型转换:容量大的类型,被强制转换成容量小的数据类型。有可能造成精度降低或数据溢出,使用时要注意。

强制类型转换:数据类型取值范围大的 转为 取值范围小的。
long l = 100L;
int i = (int)l;
但有可能造成精度降低或数据溢出,使用时要注意。

需要使用强制转换符:就是在要转换的数值前,使用小括号扩起来要转换的数据类型。

(要转换的类型)要转换的数据

示例代码:

public class Demo09Convert {

   public static void main(String[] args) {
     //1.自动类型转换:取值范围小的自动转为取值范围大的。
     short s1 = 123;//
     int i1 = s1;//隐含着将s1这个数值由short类型转为int,再赋值给i1这个变量
     System.out.println(s1);
     System.out.println(i1);
 
     byte b1 = 10;
     int i2 = b1;//byte-->int
     System.out.println(i2);
 
     //2.强制类型转换
     //byte的取值范围:-128~127之间
     byte b2 = (byte)s1;//将s1由short类型,强制转为byte类型,再赋值给byte类型的变量b2
     System.out.println(b2);//123
 
     short s2 = 128;
     byte b3 = (byte)s2;//-128
     System.out.println(b3);
 
     double d1 = 2.5;
     int i3 = (int)d1;//强制转换:浮点到整数:直接截取整数部分,忽略小数
     System.out.println(i3);
 
     long l1 = 100L;
     float f1= l1;
     System.out.println(f1);
   }
}

3、总结

自动转换:

  • A:两种类型兼容
  • B:目标类型的取值范围 大于 源类型取值范围

强制转换:

  • A:两种类型兼容
  • B:目标类型的取值范围 小于 源类型的取值范围

需要加强制转换符的语法:说明要强制转为哪种类型

(要转换的类型)数值

取值范围:

byte–>short–>int–>long–>float–>double
char

发表评论