今天我在采访中提出了一个问题.
问题是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()中传递哈希表时会发生什么所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)