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 + -
显示快捷键?