Java四类八项基本数据类型
一、 四类八项基本数据类型
1、 整数类型(byte、short、int、long)
三点注意事项:
a、 Java各整数类型有固定的表示范围和字段长度,其不收操作系统的影响,以保持Java的可移植性
b、 Java整形常量有三种表示方法:
*十进制,正常表示 如33,424;
*八进制,以0开头,如022;
*十六进制,以0X开头,如0X32等;
c、 Java的整形变量默认为int类型,申明long类型的可以在数值后面加L,比如:int i = 234;//正确 long l = 9999999999999999999999999L;//不加L则错误;
2、 浮点类型(double、float)
a、 Java各浮点类型有固定的表示范围和字段长度,其不受操作系统的影响,以保证Java的可移植性
b、 Java浮点型常量有两种表示方法:
*十进制表示,如2.2,35.66
*科学计数法形式,如3.14E2,3.14e2,3.14e-2;
c、 Java浮点类型常量默认为double型,申明float类型可以在数值后面加F,比如:double d = 2.22;//正确 float f = 3.1415926F;
3、 文本型(char)
a、 字符常量是用但信号引起来的单个字符。比如:char test1 = 'B';char test2 = '汉';
b、 Java采用unicode编码来表示,每个字符占两个字节(一个字节有八位),因此可以用十六位进制编码表示,比如:char test3 = '\u0056';
c、 Java语言还支持转移字符,来将其后面的字符转为其他含义,比如char test4 = '\n';
补充说明:
* char类型常量默认只能填写一个字符,如:char test1 = 'B';//正确;char test5 = 'zz';//错误
* 可以通过char a = '汉';;
String a = Integer.toHexString((int)a);
或
System.out.println(String.format("\\u%H",'汉'));
来看到字符所对应的unicode编码
* Java中的字符遵循Unicode,所以char经常可以当做一个无符号的整数
4、 布尔型(boolean)
布尔型只有两个值分别为true和false,不能使用0或者非0来替代,这点和C、C++等不同
二、 扩展
基本数据类型为:boolean、char、byte、short、int、long、float、double
封装类类型:Boolean、Character、Byte、Short、Integer、Long、Float、Double
以int和Integer类型为例,差别为以下几点:
1、 int声明出来的是一个常量、Integer声明出来的是一个对象;
2、 Integer num = 9;//意味着Integer num = new Integer(9);
Integer num = 9;
Integer num2 = new Integer(9);
3、 System.out.println(num == num2);输出结果为false,因为这相当于两个对象之间的比较,两个对象所指向的地址是不相同的;
Integer num = 9;
int num3 = 9;
4、 System.out.println(num == num3);输出结果为true,相当于两个参数取值比较;
5、 直接使用Integer类型进行逻辑运算时,java后台会将Integer类型默认转换为int类型;
代码中展示结果如下:
二、 高能
1、 Integer类更详细解析
首先直接看高能的例子:
首先我们要清楚Integer是int的包装类,int的初始值为0,Integer的初始值为null,Integer是一个有对象概念的类,但是输出结果的第1/2/3个true告诉了我们看问题不能太表面。
之所以会出现这个结果,主要还是因为对Integer类来说-128~127这个区间内的整数一旦声明,就会直接存储到IntegerCache中(具体可以看Integer类中的valueOf函数),所以在这个区间内声明的整数比较时实际上都是数值比较,而new Integer(127)这种方式的声明,就真的是在声明一个对象,会在内存中分配一个地址,这样在比较的过程中实际上就是地址的比较所以返回的是false。
2、 String intern()方法解析
首先看例子:
首先我们需要知道intern是什么函数
看叙述可知,如果该参数是第一次出现,则会将该参数值保存至常量池中,并返回该参数的实例引用,如果是第二次出现intern则会返回常量池中保存的实例引用。
以此观看,输出一、二、三结果皆正常,但是第四个输出为什么会是false呢?
是因为在System类中会将version信息初始化值常量池中,而在Version信息中包含java字段,因此java字段不算是第一次在常量池中出现,所以返回值为false。
3、 float精度解析
直接高能
首先float类型参数之所以会出现这个精度误差,主要是因为在内存中存储时需要转换为二进制类型存储,所以在存储的过程中很难保持参数计算的精度,所以一般我们在需要进行,浮点类型参数计算时一般通过BigDecimal+String的形式来进行数据的计算
相关示例代码之所以展示为图片还是希望能通过自己手打来加深相关知识的印象
相关引用,纯为学习,如有侵权,请联系删除
博客参考:https://blog.csdn.net/qwe969153746/article/details/53353534
最新文章
- sh6.脚本磁盘分区格式化
- 【分享】4412开发板ubuntu 12.0.4播放音乐没有声音解决方法
- Linq→join中指定多个条件
- Jquery dialog属性
- 使用EasyUI的插件前需要引入的文件
- mac gcc 编译错误 基础问题
- 集群--LVS的DR模型配置
- JQuery中的push和join
- Cracking the Code Interview 4.3 Array to Binary Tree
- python编码encode和decode
- A Tour of Go Struct Literals
- Android学习笔记--存储方案(SharedPreference、文件IO)
- Table样式设置
- 初始化git库并配置自动部署
- PID控制器开发笔记之六:不完全微分PID控制器的实现
- windows service卸载
- Spring Boot Admin 日志查看功能
- 设置TabBar图片
- NYOJ 单词拼接
- 配置Maven从私服下载构件