Java 数据类型转换
每日一句
井底点灯深烛伊,共郎长行莫围棋。
每日一句
What we call "failure" is not falling down, but the staying down. 所谓“失败”不是跌倒,而是就此躺平。
概述
数据类型的转换,分为自动转换和强制转换。自动转换是程序在执行过程中“悄然”进行的转换,不需要用户提前声明,一般是从位数低的类型向位数高的类型转换;强制类型转换则必须在代码中声明,转换顺序不受限制。
自动数据类型转换
自动转换按从低到高的顺序转换。不同类型数据间的优先关系如下:
低--------------------------------------------->高
byte,short,char-> int -> long -> float -> double
运算中,不同类型的数据先转化为同一类型,然后进行运算,转换规则如下:
操作数1类型 | 操作数2类型 | 转换后的类型 |
byte、short、char | int | int |
byte、short、char、int | long | long |
byte、short、char、int、long | float | float |
byte、short、char、int、long、float | double | double |
强制数据类型转换
强制转换的格式是在需要转型的数据前加上“( )”,然后在括号内加入需要转化的数据类型。有的数据经过转型运算后,精度会丢失,而有的会更加精确,下面的例子可以说明这个问题。
publicclassDemo{
publicstaticvoidmain(String[] args){
int x;
double y;
x = (int)34.56 + (int)11.2; *// 丢失精度*
y = (double)x + (double)10 + 1; *// 提高精度*
System.out.println("x=" + x);
System.out.println("y=" + y);
}
}
运行结果:
x=45
y=56.0
仔细分析上面程序段:由于在 34.56 前有一个 int 的强制类型转化,所以 34.56 就变成了 34。同样 11.2 就变成了 11 了,所以 x 的结果就是 45。在 x 前有一个 double 类型的强制转换,所以 x 的值变为 45.0,而 10 的前面也被强制成 double 类型,所以也变成 10.0,所以最后 y 的值变为 56。
美文佳句
很多时候,事情的困境,常常是因为我们自己钻了牛角尖,此时,你需要做的就是改变。
完美主义者可以放下执念,允许自己有普通人都会犯的小迷糊;职场妈妈可以直面现实,一个人永远做不到家庭和事业的双百分;承担了过多工作任务的员工,可以尝试向上级反映,寻求资源或调整目标……这些,都是我们应当并可以作出的改变。
正如这句话所说:世界上从来都没有所谓的奇迹,命运一直都掌握在我们自己手里。想要改变自己的命运,最重要的就是改变自己。当你开始改变自己的时候,很多东西就跟着改变了。
下一次,当烦恼降临时,不妨试试从自身找找问题。调整努力的方向和节奏,学会给心灵松绑,你会发现:很多事,其实没什么大不了。
面试题
SpringMVC 框架有什么用?
Spring Web MVC 框架提供”模型-视图-控制器”( Model-View-Controller )架构和随时可用的组件,用于开发灵活且松散耦合的 Web 应用程序。MVC 模式有助于分离应用程序的不同方面,如输入逻辑,业务逻辑和 UI 逻辑,同时在所有这些元素之间提供松散耦合。
HashMap、ConcurrentHashMap 和Hashtable有什么区别?
HashMap | ConcurrentHashMap | Hashtable | |
线程是否安全,以及实现线程安全的方式 | HashMap不安全 | 线程安全,ConcurrentHashMap JDK1.7底层采用分段锁,对整个桶数进行了分割分段(segment), 每一把锁只锁容器其中一部分数据,提高并发访问率。 JDK 1.8 底层采用 Node数组 + 链表 + 红黑树的结构实现, 并发控制使用了 synchronized 和 CAS 操作。 |
线程安全,底层采用synchronized 来保证线程安全, 直接是方法级别的加锁, ConcurrentHashMap 虽然也是 synchronized 但它是对链表或者红黑树的头节点进行加锁,锁的粒度更小 |
底层工作原理 | 底层采用的是 数组 + 链表 | ConcurrentHashMap JDK 1.7 底层采用 分段的数组 + 链表实现。 JDK 1.8 采用的是 数组 + 链表/红黑树 |
底层采用的是 数组 + 链表 |
空值问题 | HashMap允许使用null值(key和value)都可以。 但是这样的键只有一个,可以有一个或多个键所对应的值为null |
HashTable不允许null值(key和value都不可以) | |
初始容量、扩容与默认负载因子 | HashMap 默认初始大小 16,每次扩容 2n,默认负载因子是0。75 | HashTable 默认初始大小为11,每次扩容 2n+1 |