目录
首先我们都知道HashMap在线程环境下存在线程安全问题,那么有什么替代的方案呢?这就引申出第一个问题:
先说结论,ConcurrentHashMap比前两个性能要好,效率要高。
但此章节主要是针对前两个做输出。
在SynchronizedMap内部维护了一个普通对象Map,还有排斥锁mutex,如图:
Collections.synchronizedMap(new?HashMap<>(16));
我们在调用这个方法的时候就需要传入一个Map,可以看到有两个构造器,如果你传入了mutex参数,则将对象排斥锁赋值为传入的对象。
如果没有,则将对象排斥锁赋值为this,即调用synchronizedMap的对象,就是上面的Map。
创建出synchronizedMap之后,再操作map的时候,就会对方法上锁。
如图,在所有的方法上都加了synchronized锁,所以效率比较低下。