java– 当我们在Collections.synchronizedMap()中传递哈希表时会发生什么

java– 当我们在Collections.synchronizedMap()中传递哈希表时会发生什么,第1张

概述今天我在采访中提出了一个问题.问题是Collections.synchronizedMap()是用于同步地图,默认情况下不像hashmap那样是线程安全的.他的问题是,我们可以在这个方法中传递任何类型的地图.那么当我们在此方法中传递哈希表时会产生什么影响,因为哈希表默认是同步的.最佳答案如果您在SynchronizedCollection中看到代码.这些方法

今天我在采访中提出了一个问题.
问题是Collections.synchronizedMap()是
用于同步地图,默认情况下不像hashmap那样是线程安全的.
他的问题是,我们可以在这个方法中传递任何类型的地图.
那么当我们在此方法中传递哈希表时会产生什么影响,因为哈希表默认是同步的.最佳答案如果您在SynchronizedCollection中看到代码.这些方法会将调用委托给底层集合,但会在调用之上添加synchronized块

public int size() { synchronized (mutex) {return c.size();}}

在Hashtable类中,大小的实现看起来像这样

public synchronized int size() {    return count;}

因此,如果将Hashtable传递给SynchronizedCollection,则访问SynchronizedCollection的线程必须为同步块获取一次锁定,为同步方法获取另一个锁定.
如果有其他线程直接使用Hashtable对象,即使线程在SynchronizedCollection上获得锁定,它们也可以使用SynchronizedCollection来阻塞线程. 总结

以上是内存溢出为你收集整理的java – 当我们在Collections.synchronizedMap()中传递哈希表时会发生什么全部内容,希望文章能够帮你解决java – 当我们在Collections.synchronizedMap()中传递哈希表时会发生什么所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1269351.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-08
下一篇 2022-06-08

发表评论

登录后才能评论

评论列表(0条)

保存