java基础(3)--8种基本类型
八种基本类型
数据类型分为两大类:基本类型,引用类型
基本类型有8种,除了基本类型(8种)以外任何类型都是引用类型。如: String 是引用类型
基本类型有8种(首字母是小写): 整数:byte, short, int, long 浮点数(小数):float,double 布尔类型:boolean 字符类型: char
整数
整数都是有符号数(补码):
byte 8位补码 -128 ~ 127
short 16位补码 -32768 ~ 32767
int 32位补码 约-21亿 ~ 21亿 -2^31 ~ 2^31-1 -2G ~ 2G-1
long 64位补码 -2^63 ~ 2^63-1
注意点
1)任何整数“字面量”都是 int 类型! 字面量就是直接写出的常数,如:5
2)“整数字面量”在不超过范围情况下可以给“小类型变量”赋值
3)以0x为前缀的是16进制,0前缀的是8进制
4)整数超范围运算会溢出
最常用int,但是要注意范围,short很少使用,byte用于表示文件等底层数据。int a=0x7fffffff; a*2=-2
long 类型
1) 使用L后缀的字面量(直接量) 是long类型
2) 计算机时间规定: long类型 从GMT 1970年元旦开始 累计的毫秒数作为时间, 这个规定:将时间转换为整数long
3) 使用 System.currentTimeMillis() 获得系统时间
4) 时间是一个long整数!
浮点数
详细的float double 的计算规则参考 IEEE 754 标准
1. 由于float 精度比较差,很少使用,大多使用double精度:尾数长度决定 大小范围:指数(小数点位置)决定。float 的精度 没有 int 高,但是float的大小范围比int大。double的精度比float高,double的范围也比float大
int a = 0x7fffffff;
int b = 0x7ffffff0;
System.out.println(a-b);//
System.out.println(a+b);//超过int范围发生溢出了 float fa = a;//损失精度,舍入误差
float fb = b;
System.out.println(fa-fb);//0.0 说明float精度不高,有误差
System.out.println(fa-fb);//正确 float 范围比int大 double da = a;
double db = b;
System.out.println(da-db);//15.0 double精度比int高
System.out.println(da-db);//正确 double比int范围大,比float范围大
2. 浮点数字面量默认是double 类型 D为后缀是double f 后缀是float
3. 浮点数运算的不精确性, 避免使用浮点数进行精确计算。
2.6-2.0不精确 因为底层是将2.6 2.0转换成二进制运算的,2.6不能精确转换成(无限循环),2.0可以精确转换成二进制。所以结果不精确。小数只有.0和.5才能精确转换成二进制。
Java 中精确小数计算的解决方案 ,BigDecimal API类实现了精确的定点小数计算
BigDecimal x = new BigDecimal("2.6");
BigDecimal y = new BigDecimal("2");
BigDecimal z = x.subtract(y);//subtract 减法
z = x.add(y);//加
z = x.multiply(y).multiply(y);//乘法
z = x.divide(y); //除
float和double
float:1bit(符号位) 8bits(指数位) 23bits(尾数位)
double:1bit(符号位) 11bits(指数位) 52bits(尾数位)
范围:float的指数范围为-127~+128,而double的指数范围为-1023~+1024;float的范围为-2^128 ~ +2^128,也即-3.40E+38 ~ +3.40E+38;double的范围为-2^1024 ~ +2^1024,也即-1.79E+308 ~ +1.79E+308。
精度:float和double的精度是由尾数的位数来决定的。float的精度为6~7位有效数字;double的精度为15~16位。float精度由尾数位决定,二进制23位转成十进制约为 7到8位
boolean 类型
只有两个值:true 真, false 假;用来表示判断结果状态的
字符类型
1. 字符是一个16位无符号"整数"! 字符的数值是unicode编码值;char是16位无符号整数,最高位不是符号位,也是数值。范围是0~2的16次方-1 即整数范围:0 ~ 65535
2. unicode编码 8万多字。规定:'中' 编码数字 20013 '田' 编码数字 30000 'A' 编码数值 65 unicode英文编码与ASCII编码一致
3. Java char 类型支持了 i18n(国际化), 就是支持全球文字
4. 在中文本地系统中,字库(字模)只能显示20000+文字!
5. 字符字面量 就是一个char整数字面量 '中'
6. 字符可以参与数学运算
'A' 的编码 65
'B' 66
...
'Z' 90
'0' 48
'1' 49
...
7. 特殊字符,可以使用转义字符书写
'\n' new line 换行
'\r' return 回车
'\t' tab 字符
'\\' \ 字符
'\'' 单引号
'\"' 双引号
'\u4e2d' unicode 16进制编码
8. 控制字符也是字符,如:回车,换行,退格等,但是控制字符输出显示效果不明显
类型转换
自动类型转换 也称为 隐式类型转换。从小类型向大类型转换 , 发生符号位扩展现象。负数扩展为1 ,正数扩展为0
int i = -1;//i 是32位数
long l = i;//l 是64位数, 发生符号位扩展现象
System.out.println(l);//-1
System.out.println(Integer.toBinaryString(i));
System.out.println(Long.toBinaryString(l));
//Long.toBinaryString方法的参数是long类型,在i向long 类型参数传递时候发生了自动类型转换!
System.out.println(Long.toBinaryString(i));
强制类型转换
大类型到小类型的转换。在范围之内的情形,强制转换没有问题。超过小类型范围,发生高位溢出现象。强制类型转换也会发生精度损失。
l = (long)(pi+0.5);//利用强制类型转换实现 4舍5入
System.out.println(l); //4舍5入
注意点
1. java 中 字面量(直接量)之间的运算,在编译期间,优化为运算结果了。
2. Java 中int类型的“字面量”,在不超过小类型范围情况下可以给小类型变量赋值
3. 由于Java编译器,不能确定变量表达式的结果,不允许直接将大类型变量给小类型赋值 。
int n = 2;
char c;
c = 'A'+2;// int 67 没有编译错误
//c = 'A'+n;//编译错误,不能转换int到char
c = (char)('A'+n);
java基础(3)--8种基本类型的更多相关文章
- Java中的两种异常类型及其区别?
Java中的两种异常类型是什么?他们有什么区别? Throwable包含了错误(Error)和异常(Excetion两类) Exception又包含了运行时异常(RuntimeException, 又 ...
- Java基础知识点1:基本类型包装类
基本类型的包装类 简介 通常来说我们在程序中经常会使用元类型,比如 int data = 1; float data = 2.1F; 但是在有些场景中不能直接使用元类型,比如如果我们想要建立一个int ...
- Java基础知识➣环境搭建与类型整理(一)
概述 公司业务需要,产品既要有.NET又需要Java,没得选择,只能业余时间学习Java,整体觉得Java也.NET还是很相似的,只是语法有差别,差别也不是很大,这就将学习Java的基础知识整理下,以 ...
- Java基础之8个基本类型及基本类型间转换
8种基本数据类型 Java语言有8种基本数据类型, 分别用于存储整数.浮点数.字符数据和布尔类型数据.需要注意的是: 现在所介绍的仅仅是基本数据类型,后续还会介绍很多非基本数据类型.基本数据类型如图 ...
- Java基础:8种基本数据类型,取值范围和储存字节说明。
Java中,一共有8种基本数据类型: 4种整数型:int,short,long,byte. 2种浮点型:float,double. 1种字符类型:char. 1种表示真值的类型:boolean. [S ...
- JAVA基础之两种核心机制
突然之间需要学习Java,学校里学的东西早就忘记了,得用最短的时间把Java知识理顺,重点还是J2EE,毕竟所有的ava项目中95%都是J2EE,还是先从基础的J2SE学起吧....... 首先是了解 ...
- Java 基础【09】 日期类型
java api中日期类型的继承关系 java.lang.Object --java.util.Date --java.sql.Date --java.sql.Time --java.sql.Time ...
- Java基础之RTTI 运行时类型识别
运行时类型识别(RTTI, Run-Time Type Identification)是Java中非常有用的机制,在Java运行时,RTTI维护类的相关信息. 多态(polymorphism)是基于R ...
- Java 基础【12】 日期类型
java api中日期类型的继承关系 java.lang.Object --java.util.Date --java.sql.Date --java.sql.Time --java.sql.Time ...
随机推荐
- python之list去重
问题就是对一个list中的新闻id进行去重,去重之后要保证顺序不变. 直观方法 最简单的思路就是: 复制代码代码如下: ids = [1,2,3,3,4,2,3,4,5,6,1]news_ids = ...
- android应用安全——组件通信安全(Intent)
这里主要涉及到了Activity.Content Provider.Service.Broadcast Receiver等.这些如果在Androidmanifest.xml配置不当,会被其他应用调用, ...
- acdream1415(dij+优先队列+桥)
这题好坑,卡SPFA... 无奈只能用dij+优先队列了. 因为好久没有写过代码了,所以今天写dij时候突然觉得复杂度不对,dij+优先队列的复杂度是(n+m)logn,这种复杂度对于稠密图是非常慢! ...
- 如何用redis来生成唯一Id
在之前的项目中需要用到一个自动增长的主键,该主键需要包含字母,所以没有办法用到数据库的自增主键.楼主要高手的指导下,发现Redis的RedisAtomicLong类可以解决这个麻烦.而且redis为单 ...
- 局域网查看工具Lansee注册码
相信好多人为查看局域网IP发愁,今天给大家推荐一个工具 lansee 猛戳下载
- 【IDEA】安装Jrebel插件:JRebel6.4.3+破解补丁
Jrebel 通过社交分享得到的激活码不能用了.在网上找了一波,发现通过反向代理破解最好,但激活过程中报错 Check your network connection and/or VPN setti ...
- CodeForces 157A Game Outcome
A. Game Outcome time limit per test 2 seconds memory limit per test 256 megabytes input standard inp ...
- 《挑战程序设计竞赛》2.6 数学问题-快速幂运算 POJ1995
POJ3641 此题应归类为素数. POJ1995 http://poj.org/problem?id=1995 题意 求(A1^B1+A2^B2+ - +AH^BH)mod M. 思路 标准快速幂运 ...
- HTTP 错误 500.21 - Internal Server Error 解决方案(转)
不久前重新安装了Windows7,在安装了VS2010 开发平台之后,将网站发布到IIS,访问发生如下错误: HTTP 错误 500.21 - Internal Server Error处理程序“Ni ...
- DB2中编目本机其中数据库的方法
问题:同一节点上有两个实例.假设想在当中一个实例下訪问还有一个实例中的数据库,有两种方法: 1. 使用catalog local node的方式,在当中一个实例中将另外一个实例直接编目,这样的方试中, ...