首页 / JAVA / Java 变量与数据类型(三)
Java 变量与数据类型(三)
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了Java 变量与数据类型(三),小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含4068字,纯文字阅读大概需要6分钟。
内容图文
整数类型
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
内容总结
以上是互联网集市为您收集整理的Java 变量与数据类型(三)全部内容,希望文章能够帮你解决Java 变量与数据类型(三)所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。