我想知道當(dāng)我修改當(dāng)前值并將其放入ConcurrentHashMap.我有ConcurrentHashMap( ConncurentHashMap<String, Integer> attendance) 現(xiàn)有的會(huì)議廳名稱(chēng)映射和每個(gè)會(huì)議廳的訪(fǎng)客數(shù)量。每次調(diào)用visit(conferenceHallName)方法都應(yīng)該增加給定會(huì)議廳的訪(fǎng)客數(shù)量。每個(gè)調(diào)用者都是一個(gè)線(xiàn)程。所以這是方法:public void visit(String conferenceHallName) {
attendance.put(conferenceHallName, attendance.get(conferenceHallName) + 1);
}put()是鎖定方法,get()不是。但是在這種情況下首先會(huì)發(fā)生什么:線(xiàn)程將使用此映射鎖定段,然后計(jì)算一個(gè)新值,然后放入并釋放這對(duì)我來(lái)說(shuō)是完美的或線(xiàn)程將獲取舊值,計(jì)算一個(gè)新值,然后鎖定段并放置,這對(duì)我來(lái)說(shuō)意味著不一致,我需要找到一個(gè)解決方法。如果第二種情況是現(xiàn)實(shí)中發(fā)生的情況,使用AtomicInteger而不是Integer解決我的問(wèn)題?
在 ConcurrentHashMap 中放置線(xiàn)程安全的同時(shí)增加當(dāng)前值?
千萬(wàn)里不及你
2023-01-05 10:11:47