-这两天在刷面试题,感觉进制转换和数据类型以及其占用的字节挺重要的,整理一下。
- 进制的转化
- 原码、补码、反码
- 数据类型
- 数据类型的转换
进制的转换
1、其他进制到十进制
系数:就是每一个位上的数值
基数:x进制的基数就是x
权:对每一个位上的数据,从右,并且从0开始编号,对应的编号就是该数据的权。
结果:系数*基数^权次幂之和。
2、十进制转化为其他进制
除基取余,直到商为0,余数反转。
原码、补码、反码
在计算机内,有符号数有3种表示法:原码、反码、补码。所有数据的运算都采用补码进行。
原码:
二进制的定点表示法,最高位为符号位。“0”表示正数,“1”表示负数,其余位表示数值的大小。
反码:
正数的反码与源码相同;负数的反码对其原码逐位取反,符号位除外。
补码:
正数的补码与其原码相同;负数的补码是其在反码的末位加1。
举例计算(以+7和-7为例):
计算原码(正数的原码最高位是0,负数的原码最高位是1,其余位是数值位)
数字 | 符号位 | 数值位 |
---|---|---|
+7 | 0 | 0000111 |
-7 | 1 | 1000111 |
计算反码(正数的反码与原码相同,负数的反码与原码符号位相同,数值位取反)
数字 | 符号位 | 数值位 |
---|---|---|
+7 | 0 | 0000111 |
-7 | 1 | 1111000 |
计算补码(正数的补码与原码相同,负数的补码在反码基础上加1)
数字 | 符号位 | 数值位 |
---|---|---|
+7 | 0 | 0000111 |
-7 | 1 | 1111001 |
数据类型
类型 | 占用存储空间 | 表数范围 |
---|---|---|
byte | 1字节 | -128~127 |
short | 2字节 | -2^15~2^15-1 |
int | 4字节 | -2^31~2^31-1 |
long | 8字节 | -2^63~2^63-1 |
float | 4字节 | -3.403E38~3.403E38 |
double | 8字节 | -1.798E308~2^1.798E308 |
整数默认:int,小数默认:double
长整形后缀用L标注!(数据不在int范围内要加L)
单精度浮点数用F标注!
数据类型的转换
默认转换:byte,short,char—int—long—float—double
Byte,short,char之间不转换,他们参与运算首先转换为int型
public class Mima {
public static void main(String[] args) {
//两个整型做加法
int x =3;
int y = 4;
int z = x + y;
System.out.println(z);
//定义一个byte类型,一个int类型,做加法
byte a = 3;
int b = 4;
System.out.println(a + b);
byte c = a + b;
System.out.println(c);
}
}
这段代码在byte c = a + b;会出现错误(Type mismatch: cannot convert from int to byte),需要类型转换!
分析一下为什么????
注意问题
byte,short在定义的时候,他们接收的其实是一个int类型的值。这个是自己做了一个数据检测的,如果不再它们的范围内,就报错。
1、byte值的问题
byte b1 = 127;
byte b2 = (byte)128; //-128
byte b3 = (byte)129; //-127
byte b4 = (byte)130; //-126
byte的范围:-128 ~ 127
128:10000000
-128:10000000 (这里的1即是符号位,也是数值位)
2、数据类型转换之默认转换
byte,short,char – int – long – float – double
3、Java语言中的字符char可以存储一个中文汉字吗?为什么呢?
可以。因为java语言中的字符占用两个字节。 Java语言采用的是Unicode编码。
面试题一
byte b1=3,b2=4,b;
b=b1+b2;
b=3+4;
哪句编译错误?为什么?
答案
b=b1+b2//会出现问题,变量计算时时以int类型计算的
b=3+4;//不会出现问题,常量相加,先计算结果,然后看是否在byte范围内,如果在就不报错。
面试题二
byte b = 130;有没有错?如果想让赋值正确,可以怎么做?结果是多少?
答案
byte的范围是:-128~127,130不在范围内,所以会报错。结果是-126