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

前端之家收集整理的这篇文章主要介绍了java – 当我们在Collections.synchronizedMap()中传递哈希表时会发生什么前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

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

最佳答案
如果您在SynchronizedCollection中看到代码.这些方法会将调用委托给底层集合,但会在调用之上添加synchronized块@H_301_10@

@H_301_10@

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

在HashTable类中,大小的实现看起来像这样@H_301_10@

@H_301_10@

public synchronized int size() {
    return count;
}

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

原文链接:https://www.f2er.com/spring/432784.html

猜你在找的Spring相关文章