基本数据类型
2016-07-27 16:27
369 查看
一:数据类型:Java是一种强类型的语言,针对每一种数据都定义了明确的数据类型。
数据类型分类:
A:基本数据类型
B:引用数据类型(类,接口,数值)
基本数据类型:4类8种
A:整数 占用字节数
byte 1
short 2
int 4
long 8
B:浮点数
float
4
double
8
C:字符
char 2
D:布尔
boolean
1
注意:
整数默认是int类型
浮点数默认是double类型。
长整型后缀用L或者l标记。建议使用L。
单精度浮点数用F或者f标记。建议使用F。
二:+是一个运算符(我们等会讲解)。做加法运算的。
一般来说,我们在运算的时候,要求参与运算的数据类型必须一致。
注意:
boolean类型不能转换为其他的数据类型
默认转换(从小到大的转换)
A:byte,short,char—int—long—float—double
B:byte,short,char相互之间不转换,他们参与运算首先转换为int类型
强制转换:
从大的数据类型到小的数据类型。
格式:
目标数据类型 变量 = (目标数据类型) (被转换的数据);
注意:
不要随意的去使用强制转换,因为它隐含了精度损失问题。
三:看看下面两个定义有没有区别呢?
float f1 = (float)12.345;
float f2 = 12.345f;
f1其实是通过一个double类型转换过来的。
而f2本身就是一个float类型。
四:面试题:
byte b1=3,b2=4,b;
b=b1+b2;
b=3+4;
哪句是编译失败的呢?为什么呢?
b = b1 + b2;是有问题的。
因为变量相加,会首先看类型问题,最终把结果赋值的也会考虑类型问题。变量是在运行时才知道其值。
常量相加,首先做加法,然后看结果是否在赋值的数据类型范围内,如果不是,才报错。常量是在编译时就知道其值 了。
五:byte b = 130;有没有问题?如果我想让赋值正确,可以怎么做?结果是多少呢?-126
class DataTypeDemo7 {
public static void main(String[] args) {
//因为byte的范围是:-128到127。
//而130不在此范围内,所以报错。
//byte b = 130;
//我们可以使用强制类型转换
byte b = (byte) 130;
//结果是多少呢?
System.out.println(b);
}
}
分析过程:
我们要想知道结果是什么,就应该知道是如何进行计算的。
而我们又知道计算机中数据的运算都是补码进行的。
而要得到补码,首先要计算出数据的二进制。
A:获取130这个数据的二进制。
00000000 00000000 00000000 10000010
这是130的原码,也是反码,还是补码。
B:做截取操作,截成byte类型的了。
10000010
这个结果是补码。
C:已知补码求原码。
符号位 数值位
补码: 1
0000010
反码: 1
0000001
原码: 1
1111110
六:
数据类型分类:
A:基本数据类型
B:引用数据类型(类,接口,数值)
基本数据类型:4类8种
A:整数 占用字节数
byte 1
short 2
int 4
long 8
B:浮点数
float
4
double
8
C:字符
char 2
D:布尔
boolean
1
注意:
整数默认是int类型
浮点数默认是double类型。
长整型后缀用L或者l标记。建议使用L。
单精度浮点数用F或者f标记。建议使用F。
二:+是一个运算符(我们等会讲解)。做加法运算的。
一般来说,我们在运算的时候,要求参与运算的数据类型必须一致。
注意:
boolean类型不能转换为其他的数据类型
默认转换(从小到大的转换)
A:byte,short,char—int—long—float—double
B:byte,short,char相互之间不转换,他们参与运算首先转换为int类型
强制转换:
从大的数据类型到小的数据类型。
格式:
目标数据类型 变量 = (目标数据类型) (被转换的数据);
注意:
不要随意的去使用强制转换,因为它隐含了精度损失问题。
三:看看下面两个定义有没有区别呢?
float f1 = (float)12.345;
float f2 = 12.345f;
f1其实是通过一个double类型转换过来的。
而f2本身就是一个float类型。
四:面试题:
byte b1=3,b2=4,b;
b=b1+b2;
b=3+4;
哪句是编译失败的呢?为什么呢?
b = b1 + b2;是有问题的。
因为变量相加,会首先看类型问题,最终把结果赋值的也会考虑类型问题。变量是在运行时才知道其值。
常量相加,首先做加法,然后看结果是否在赋值的数据类型范围内,如果不是,才报错。常量是在编译时就知道其值 了。
五:byte b = 130;有没有问题?如果我想让赋值正确,可以怎么做?结果是多少呢?-126
class DataTypeDemo7 {
public static void main(String[] args) {
//因为byte的范围是:-128到127。
//而130不在此范围内,所以报错。
//byte b = 130;
//我们可以使用强制类型转换
byte b = (byte) 130;
//结果是多少呢?
System.out.println(b);
}
}
分析过程:
我们要想知道结果是什么,就应该知道是如何进行计算的。
而我们又知道计算机中数据的运算都是补码进行的。
而要得到补码,首先要计算出数据的二进制。
A:获取130这个数据的二进制。
00000000 00000000 00000000 10000010
这是130的原码,也是反码,还是补码。
B:做截取操作,截成byte类型的了。
10000010
这个结果是补码。
C:已知补码求原码。
符号位 数值位
补码: 1
0000010
反码: 1
0000001
原码: 1
1111110
六:
相关文章推荐
- Gson的注解和策略使用
- Activity、Window、View的关系
- jsp <%%> <%!%>的区别
- Qt对基本控件进行美化 QStyle和QStyleSheet
- 智云通CRM教育培训行业解决方案助力教育培训机构稳步前进
- JQuery学习之旅(2)
- Hibernate不能建表的问题
- js自定义随机数插件:yiRan
- react-native 通常每个套接字地址(协议/网络地址/端口)只允许使用一次。
- linux下历史命令history使用方法
- 牛客网 7-27 网络基础 操作系统 编译与体系结构 30题知识点总结
- 自定义导航的两种方法
- 为什么在重写 equals方法的同时必须重写 hashcode方法
- Can't create handler inside thread that has not called
- Android实现滑动的七种方法
- js 添加删除替换class 类
- 习题28 布尔表达式练习
- 直接拿来用,最火的.NET开源项目(beta)
- 遇到的问题汇总
- 理解屏幕和资源的常见问题