面试:Java基础 3

举报
一条coding 发表于 2021/10/19 00:07:59 2021/10/19
【摘要】 请你解释为什么会出现4.0-3.6=0.40000001这种现象? 计算机在计算10进制小数的过程中要先转换为2进制进行计算,这个过程中出现了误差。出现0.40000001的情况可以使用BigDecimal类解决 请你介绍一下map的分类和常见的情况 接口java.util.Map;它有四个实现类,分别是HashMap Hasht...

请你解释为什么会出现4.0-3.6=0.40000001这种现象?

计算机在计算10进制小数的过程中要先转换为2进制进行计算,这个过程中出现了误差。出现0.40000001的情况可以使用BigDecimal类解决

请你介绍一下map的分类和常见的情况

接口java.util.Map;它有四个实现类,分别是HashMap Hashtable LinkedHashMap 和TreeMap.

Map主要用于存储健值对,根据键得到值,因此不允许键重复(重复了覆盖了),但允许值重复

它根据键的HashCode值存储数据,遍历时,取得数据的顺序是完全随机的。

HashMap最多只允许一条记录的为Null;允许多条记录的为 Null;

HashMap不支持线程的同步,即任一时刻可以有多个线程同时写HashMap;可能会导致数据的不一致。如果需要同步,可以用 Collections的synchronizedMap方法使HashMap具有同步的能力,或者使用ConcurrentHashMap。

Hashtable与 HashMap类似,它继承自Dictionary类,不同的是:它不允许记录的键或者值为空;它支持线程的同步,即任一时刻只有一个线程能写Hashtable,因此也导致了 Hashtable在写入时会比较慢。

LinkedHashMap 是HashMap的一个子类,保存了记录的插入顺序。

TreeMap实现SortMap接口,能够把它保存的记录根据键排序,默认是按键值的升序排序,也可以指定排序的比较器,当用Iterator 遍历TreeMap时,得到的记录是排过序的。

 请你谈谈关于Synchronized和lock 

synchronized是Java的关键字,当它用来修饰一个方法或者一个代码块的时候,能够保证在同一时刻最多只有一个线程执行该段代码。synchronized在发生异常时,会自动释放线程占有的锁,因此不会导致死锁现象发生;synchronized修饰静态方法以及同步代码块的synchronized (类.class,需要获得类锁。synchronized修饰成员方法,线程获取的是当前调用该方法的对象锁。JDK1.5以后引入了自旋锁、锁粗化、轻量级锁,偏向锁来有优化关键字的性能。

Lock是一个接口,而Lock在发生异常时,如果没有主动通过unLock()去释放锁,则很可能造成死锁现象,因此使用Lock时需要在finally块中释放锁;Lock可以让等待锁的线程响应中断,而synchronized却不行,使用synchronized时,等待的线程会一直等待下去,不能够响应中断;通过Lock可以知道有没有成功获取锁,而synchronized却无法办到。

 请你介绍一下volatile?

volatile关键字是用来保证有序性和可见性的。

 

 

文章来源: blog.csdn.net,作者:一条coding,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/skylibiao/article/details/97120840

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。