java数据类型

来源:互联网 发布:stussy淘宝正品店 编辑:程序博客网 时间:2024/06/05 21:53

数据类型

Java 基本数据类型

java是强类型语言,针对每种数据都定义了明确的数据类型。
变量就是申请内存来存储值。也就是说,当创建变量的时候,需要在内存中申请空间。
内存管理系统根据变量的类型为变量分配存储空间,分配的空间只能用来储存该类型数据。

因此,通过定义不同类型的变量,可以在内存中储存整数、小数或者字符。
Java 的两大数据类型:
内置数据类型
引用数据类型

内置数据类型

Java语言提供了八种基本类型。六种数字类型(四个整数型,两个浮点型),一种字符类型,还有一种布尔型。

byte:

    byte 数据类型是8位、有符号的,以二进制补码表示的整数;    最小值是 -128(-2^7);    最大值是 127(2^7-1);    默认值是 0;    byte 类型用在大型数组中节约空间,主要代替整数,因为 byte 变量占用的空间只有 int 类型的四分之一;    例子:byte a = 100,byte b = -50。

short:

    short 数据类型是 16 位、有符号的以二进制补码表示的整数    最小值是 -32768(-2^15);    最大值是 32767(2^15 - 1);    Short 数据类型也可以像 byte 那样节省空间。一个short变量是int型变量所占空间的二分之一;    默认值是 0;    例子:short s = 1000,short r = -20000。

int(默认整数):

    int 数据类型是32位、有符号的以二进制补码表示的整数;    最小值是 -2,147,483,648(-2^31);    最大值是 2,147,483,647(2^31 - 1);    一般地整型变量默认为 int 类型;    默认值是 0 ;    例子:int a = 100000, int b = -200000。

long:

long 数据类型是 64 位、有符号的以二进制补码表示的整数;
最小值是 -9,223,372,036,854,775,808(-2^63);
最大值是 9,223,372,036,854,775,807(2^63 -1);
这种类型主要使用在需要比较大整数的系统上;
默认值是 0L;
例子: long a = 100000L,Long b = -200000L。
“L”理论上不分大小写,但是若写成”l”容易与数字”1”混淆,不容易分辩。所以最好大写。

float(单精度):

    float 数据类型是单精度、32位、符合IEEE 754标准的浮点数;    float 在储存大型浮点数组的时候可节省内存空间;    默认值是 0.0f;    浮点数不能用来表示精确的值,如货币;    例子:float f1 = 234.5f。

double(双精度、默认浮点型):

double 数据类型是双精度、64 位、符合IEEE 754标准的浮点数;
浮点数的默认类型为double类型;
double类型同样不能表示精确的值,如货币;
默认值是 0.0d;
例子:double d1 = 123.4。

boolean:

    boolean数据类型表示一位的信息;    只有两个取值:true 和 false;    这种类型只作为一种标志来记录 true/false 情况;    默认值是 false;    例子:boolean one = true。

char:

    char类型是一个单一的 16 位 Unicode 字符;    最小值是 \u0000(即为0);    最大值是 \uffff(即为65,535);    char 数据类型可以储存任何字符;    例子:char letter = 'A';。

在Java运算过程中必须保持数据类型是一直的、byte short char (他们三者之间不会相互转换)在做运算的时候会自动转换成int,即小的自动转换成大的。

默认数据转换:

Byte、short、char、->int—>long
例如:

byte a = 3;int  b = 4;int num = a + b;     这样在运算过程中byte会自动换成int,默认数据转换

但在运算过程中大的转换成小的就可能会造成精度丢失就不可以了(要进行强制转换)Byte——>int //这种就是不不可取的,

强制数据类型转换:

格式: 数据类型 变量名 = (目标数据类型)
例如:byte b1 = (byte)(a+b); //需要注意的是“a+b”需要加括号
Java 默认整数类型为“int”,小数默认double类型

Ps: 即使强行转换也是可能出现数据精度丢失、强行转换慎用
变量在做相加的时候,会先看数据类型。来看下面的代码:
Byte b1 =3;
Byte b2=4;
Byte b3=b1+b2; //这句代码有问题,b1和b2都是变量,在运算过程中变量会先转换 成int,因此不能赋给byte

Byte b4=3+4; //这个就没问题了,常量是先计算,如果byte可以放下,那么就不会报错

Ps:任何类型在和字符串做运算(前提是字符串在前),结果都是字符串。这是“+”这个符号就成为一个连接符,完成字符串的拼接。
例如:System.out.println(“5+5=”+5+5) //结果就是5+5=55
System.out.println(5+5+“=5+5”) //结果就是10=5+5

原创粉丝点击