一、基本类型介绍

关键字 数据类型 占用字节数 取值范围 默认值
byte 字节型 1个字节 -128~127 0
char 字符型 2个字节 Unicode0~Unicode215-1 \u0000
short 短整型 2个字节 -215~215-1 0
int 整型 4个字节 -231~231-1 0
long 长整型 8个字节 -263~263-1 0
float 单精度浮点数 4个字节 -2128~2128 0.0
double 双精度浮点数 8个字节 -21024~21024 0.0
boolean 布尔型 1个字节 true|false false

float与double的范围和精度

  范围

  float:      1bit(符号位)  8bit(指数位)  23bit(尾数为)

  double:   1bit(符号位)  11bit(指数位)  52bit(尾数为)

float的指数范围 -127~128,而double的指数范围-1023~1024

  float的范围为-2128~2128,也即-3.40E+38 ~ +3.40E+38;double的范围为-21024~21024,也即-1.79E+308 ~ +1.79E+308

  精度

  float和double的精度是由尾数的位数来决定的。浮点数在内存中是按科学计数法来存储的,其整数部分始终是一个隐含着的“1”,由于它是不变的,故不能对精度造成影响。

  float:223 = 8388608,一共七位,这意味着最多能有7位有效数字,但绝对能保证的为6位,也即float的精度为6~7位有效数字;
    double:252 = 4503599627370496,一共16位,同理,double的精度为15~16位。

基本类型赋值

  byte:

byte b=1;
byte a=1+2;

  short

short s=1;

  char

char a='A';                   //直接用字符赋值
char b=65; //用10进制数字赋值
char c='\u0041'; //使用unicode码赋值
char d=0x0041; //使用16进制赋值
char e=0101; //使用8进制赋值
System.out.println(a);
System.out.println(b);
System.out.println(c);
System.out.println(d);
System.out.println(e);

上面输出的都是是字符'A'

  int

int a=3;

  long

long a=1;
long b=10000000000l;
//如果赋值范围超过了int,就必须在后面加上字母l或者L

  float

float a=1.2f;

  double

double a=1.2;

二、基本类型运算

1、java中byte、short和char类型运算操作首先会把这些值转换成int类型,然后对这些int值进行运算,返回int类型。

byte a=1;
byte b=2;
byte c=a+b; 这里先将a和b转换成int类型在进行计算,结果返回int类型,所以这里结果不正确
可以改为:
int c=a+b;
或者
byte c=(byte)(a+b); 当然这里不能操作byte范围
byte a=1;
char b='B';
int c=a+b;
System.out.println(c);

输出为67  现将a=1和b='B'转换成int型 a=1、b=66 所以结果为67

2、在做除法运算时,如果两边除数和被除数都是整数,其结果也为整数(只保留整数部分)例如:

int a=10;
int b=3;
System.out.println(a/b);

结果为:3

3、在做除服运算时,两个操作数其中有一个是浮点数,计算结果也是浮点数。而且允许除数是0或者0.0,得到结果正无穷或负无穷

double a=5;
int b=5;
System.out.println(a/0); //结果为正无穷:Infinity
System.out.println(-a/0); //结果为负无穷:-Infinity
System.out.println(b/0); //抛出异常:java.lang.ArithmeticException: / by zero
System.out.println(0/0.0); //结果为:NaN
System.out.println(0.0/0); //结果为NaN

基本类型常见面试题

最新文章

  1. Xamarin技术文档------VS多平台开发
  2. ORACLE 创建作业JOB例子
  3. AC日记——产生数 codevs 1009 (弗洛伊德)(组合数学)
  4. 明白python文件如何组织,理解建立源文件
  5. 查看Linux软件信息
  6. 关于Excel导入的HDR=YES; IMEX=1详解
  7. Border - SGU 133(排序)
  8. lightoj 1236 正整数唯一分解定理
  9. Python3实现简单的http server
  10. SSM所需的jar
  11. Maven的下载、安装与环境配置
  12. 空间数据可视化之ArcLayer详解
  13. 19.java反射入门
  14. Golang学习---常用库
  15. Nexus 3 搭建 npm 私服 (windows)
  16. 索引使用,分析初探。(explain分析执行计划,以及强制使用force index)
  17. 洛谷P1057传球游戏题解
  18. 20165336 2017-2018-2 《Java程序设计》第1周学习总结
  19. Open Tools API :IDE Main Menus
  20. Oracle中rownum用法警示

热门文章

  1. 与Win8之磁盘活动时间100%斗争心得
  2. java转换emoji表情
  3. 解决TextView排版混乱或者自动换行的问题
  4. 如何在Jenkins中使用环境变量
  5. 【POJ】【2187】Beauty Contest
  6. @JVM新一代的垃圾回收算法
  7. 第二十三章 springboot + 全局异常处理
  8. 第二章 JVM内存分配
  9. CentOS 7 中 hostnamectl 的使用
  10. VS2008中生成DLL项目