Java 变量与数据类型(三)

整数类型

1、Java有四种整数类型:byte、short、int和long

2、Java默认整数计算的结果是int类型。

3、整数的字面量是int类型。

4、若字面量超过int类型的最大值,则字面量是long类型,那么后面要用L(或l)表示该值是long类型。

【示例】将字面量30亿赋值给一个long类型的变量:

long longValue=3000000000L;

5、Java底层byte和short按照32位(int类型)计算。

【示例】以下注释语句去掉,结果是?

 浮点类型 

1、浮点类型用于表示小数的数据类型。

2、浮点数原理:也就是二进制科学计数法。

3、Java的浮点类型有float和double两种。

4、Java默认浮点类型计算的结果是double类型,字面量也是double类型。

若要给floath类型的变量赋字面量的值,则要在字面量后加F(或f)

【示例】float  f=5.3;将会出现编译错误,正确的赋值是:float f=5.3f;

浮点类型科学计数法???

1、十进制浮点数科学计数法:219345=2.19345*(10^5)

2、二进制浮点数科学计数法:10111=1.0111*(2^100) 以

2.19345*(10^5)为例介绍如下概念:

尾数:2.19345(表示该值的精确度)

指数:5

基数:10

Float 类型???

1、float 类型共32位,1位为符号位,指数8位,尾数23位。

2、float 的精度是23位(即能精确表达23位的数,超过就被截取了)。小数是以尾数长度来表示精确度的,

比如:pi=3.1415的精度是4位。

3、float 存储数据的范围大于int类型,但精度比int要小,因为int的精度是31位。

double类型???

1、double类型,1位符号位,11位指数,52位尾数。

2、double范围远远大于long,但double精度不如long(long存储数据的位数是63位)。

浮点运算???

浮点运算就是实数运算,由于计算机只能存储整数,所以实数都是约数,这样浮点运算是很慢的而且会有误差。

 字符类型

1、char类型的字面量可以是一个英文字面、字符或一个汉字,并且由单引号包括。

例如:'A' 、‘3’、‘a’、‘\n’

2、Java底层使用一个16位的整数来处理字符类型,该数值是一个字符的unicode编码的值。

Unicode编码???

1、unicode编码时全球范围内的编码方法。(用来处理中、英文、日、韩、阿拉伯、希伯来等文字的字符,共有大约8万多个字符。)

2、unicode编码的英文部分与ASCII码兼容(ASCII 表示范围0~128),同时英文字符和数字是连续编码的。

3、Java在处理char类型的数据时,在底层是按unicode码来处理的。

4、编码是什么??

计算机硬件系统只能用0和1表示数,我们人为地做了规定,某个数还可以表示一个字符。

例如:65代表的字符是A
 

输出unicode码从0~127的所有字符:

转义符

转义字符是"\n",通过转义字符,可表示一些特殊的字符。

例如:'\n' 表示回车 

'\t' 表示制表位字符,一个制表符表示向右跳8-10个字符,

'\\' 表示 \

' \' ' 表示单引号

' \'" ' 表示双引号

'\u4e2d' 表示unicode编码对应的字符(汉字:中)

布尔类型的概念和用法 

1、什么是布尔类型

boolean类型用来表示肯定或者否定两种可能。

2、为什么使用布尔类型?

布尔类型常用在分支语句、循环语句中。

3、boolean类型的值有两个:

true:表示肯定意义;false:表示否定意义;

4、布尔变量的意义

boolean  isPass;

5、布尔变量的初始化

boolean isPass=true

isPass=59>=60;

 小类型向大类型转换

不同类型的数据经常出现相互转换的现象。(需要进行数据类型的转换,否则会出现编译器的错误)
       例如:byte b1=5;  byte b2=b1+10

小类型向大类型转换???

1、小类型向大类型的转换会自动完成,即不需要程序员编写额外的代码,由JVM负责。

提示:自动类型转换也叫 “隐式类型转换”

2、自动转换的规则:符号位会自动扩展,负数补1,正数补0。

3、自动类型转换包含以下情况:

(1)byte->short->int->long->float->double

(2)int 和 char类型的数据在某些情况下可以自动相互转换。

4、整数到浮点数转换会损失精确度。

【示例】int类型的数据自动转换为long类型的数据

 小类型向大类型转换案例

1、小类型向大类型转换一般情况下是安全的。

2、当小类型的精度高于大类型时要注意精度丢失的隐患。

int类型转换成float类型:(虽然不会出现数据丢失,但是有可能会出现精度丢失的问题)

int 类型的精度都是31位,int类型32位中最高位是符号位,剩下的31位是用来存储数据的,因此他的尾数是31。

float类型也是32位,但尾数是23位。

 

long类型转换成double:

【示例】long类型转换成double类型的精度丢失:

大类型向小类型转换

  1、强制类型转换-简称强转

       例如:byte b=5;

                 b=(byte)(b+10);

                 b=5+10; 无需类型转换

  2、强制类型转换时,要注意边界数风险问题。

  【示例】大类型转换小类型时,源数据的数据位变为目标数据的符号位。

   int  i=129

   byte b=(byte) i;

   变量b的值是多少?:10000001=129

   011111111  逐位取反再加1

   结果:-127

   【示例】

    大类型的数据超过了小类型的位数示例。

    int i=257;

    byte b=(byte) i ;

    变量b的值是多少?

    10000,0001=257

      0000,0001 最高位抛弃结果是 1

猜你喜欢

转载自blog.csdn.net/u013491829/article/details/106456984