proxycallback.java
来自「memcached JAVA客户端API,应用广泛,运行比较稳定。」· Java 代码 · 共 65 行
JAVA
65 行
/** * */package net.spy.memcached.protocol;import java.util.ArrayList;import java.util.Collection;import java.util.HashMap;import java.util.Map;import net.spy.memcached.ops.GetOperation;import net.spy.memcached.ops.OperationStatus;/** * Proxy callback used for dispatching callbacks over optimized gets. */public class ProxyCallback implements GetOperation.Callback { private final Map<String, Collection<GetOperation.Callback>> callbacks= new HashMap<String, Collection<GetOperation.Callback>>(); private final Collection<GetOperation.Callback> allCallbacks= new ArrayList<GetOperation.Callback>(); public void addCallbacks(GetOperation o) { GetOperation.Callback c=new GetCallbackWrapper(o.getKeys().size(), (GetOperation.Callback)o.getCallback()); allCallbacks.add(c); for(String s : o.getKeys()) { Collection<GetOperation.Callback> cbs=callbacks.get(s); if(cbs == null) { cbs=new ArrayList<GetOperation.Callback>(); callbacks.put(s, cbs); } cbs.add(c); } } public void gotData(String key, int flags, byte[] data) { Collection<GetOperation.Callback> cbs=callbacks.get(key); assert cbs != null : "No callbacks for key " + key; for(GetOperation.Callback c : cbs) { c.gotData(key, flags, data); } } public void receivedStatus(OperationStatus status) { for(GetOperation.Callback c : allCallbacks) { c.receivedStatus(status); } } public void complete() { for(GetOperation.Callback c : allCallbacks) { c.complete(); } } public int numKeys() { return callbacks.size(); } public int numCallbacks() { return allCallbacks.size(); }}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?