Merge pull request #3214 from dotnet-maestro-bot/merge/release/2.2-to-master

[automated] Merge branch 'release/2.2' => 'master'
This commit is contained in:
Mikael Mengistu 2018-10-26 13:55:51 -07:00 коммит произвёл GitHub
Родитель 64222fa735 e1b602a7c5
Коммит 86f4e80ecf
Не найден ключ, соответствующий данной подписи
Идентификатор ключа GPG: 4AEE18F83AFDEB23
1 изменённых файлов: 29 добавлений и 13 удалений

Просмотреть файл

@ -3,29 +3,45 @@
package com.microsoft.signalr;
import java.util.*;
import java.util.concurrent.ConcurrentHashMap;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.concurrent.locks.ReentrantLock;
class CallbackMap {
private final Map<String, List<InvocationHandler>> handlers = new ConcurrentHashMap<>();
private final Map<String, List<InvocationHandler>> handlers = new HashMap<>();
private final ReentrantLock lock = new ReentrantLock();
public InvocationHandler put(String target, ActionBase action, Class<?>... classes) {
InvocationHandler handler = new InvocationHandler(action, classes);
handlers.compute(target, (key, value) -> {
if (value == null) {
value = new ArrayList<>();
try {
lock.lock();
InvocationHandler handler = new InvocationHandler(action, classes);
if (!handlers.containsKey(target)) {
handlers.put(target, new ArrayList<>());
}
value.add(handler);
return value;
});
return handler;
handlers.get(target).add(handler);
return handler;
} finally {
lock.unlock();
}
}
public List<InvocationHandler> get(String key) {
return handlers.get(key);
try {
lock.lock();
return handlers.get(key);
} finally {
lock.unlock();
}
}
public void remove(String key) {
handlers.remove(key);
try {
lock.lock();
handlers.remove(key);
} finally {
lock.unlock();
}
}
}