C/S FrameWork 之中 Action的处理-----分发机制

C/S FrameWork 之中 Action的处理-----分发机制

首先我想简单介绍一下 C/S FrameWork,这里面实现了 客户端与服务器端的简单通信,其中 发送网络消息请求资源,(这里定义的网络消息 由三部分组成: Command、Action、para)
其中 不同的Command需要 客户端 app层 进行实现,故在Client里面设置有接口,然后再ClientConversation 之中调用方法。

@Override
这是 ClinentConversation里面的代码 
	protected void dealNetMessage(NetMessage message) {
		String para = message.getPara();
		String action = message.getAction();
		switch (message.getCommand()) {
		//处理强制宕机
		case FORCE_DOWN:
			client.getClientAction().serverForcedown();
			close();
			break;
			//私发消息
		case TO_ONE:
			client.getClientAction().privateConversation(action, para);
			break;
			//处理上线
		case ID:
			setId(para);
			break;
		default:
			break;
		}
	}
这里是 接口代码
public interface IClientAction {
	void serverAbnormalDrop();
// TODO
}
这是客户端 getClientAction()方法的代码
IClientAction getClientAction() {
		return clientAction;
	}

看到这里有人禁不住 要问 客户端APP要实现的功能可不止这些啊,要是有其他功能,那我们可不可以只在ClinentConversation 写出相应的方法,而是不还要写一堆 switch 和case的代码呢!
这里 我们自己也应当反思一下,这里dealNetMessage()方法确实不是很纯粹,接下啦我们利用反射机制 来进行处理

增加一个类DealNetMessage,这个类里面,可以利用Command 生成相应的方法名称
deal+“”,

private static String getMethodName(String command) {
		StringBuffer result = new StringBuffer("deal");
		
		String[] words = command.split("_");
		int wordCount = words.length;
		for (int i = 0; i < wordCount; i++) {
			result.append(words[i].substring(0, 0+1).toUpperCase());
			result.append(words[i].substring(1).toLowerCase());
		}
		
		return result.toString();
	}

运用反射机制

public static void dealCommand(Object object, NetMessage message) {
		Class<?> klass = object.getClass();
		String methodName = getMethodName(message.getCommand().name());
		Method method;
		try {
			method = klass.getMethod(methodName, NetMessage.class);
// 参数为:MethodName以及 方法的arg.class
			method.invoke(object, message);
//参数为对象的值,以及要反射机制执行的方法的参数的值
		} catch (Exception e) {
			e.printStackTrace();
		}
	}

那么之前在Conversation里面写的dealNetMessage()变成了现在这个样子

//处理单发
public void dealToOne(NetMessage message) {
		String action = message.getAction();
		String para = message.getPara();
		client.getClientAction().privateConversation(action, para);
	}
//处理 超员
	public void dealOutOfRoom(NetMessage message) {
		client.getClientAction().outOfRoom();
		close();
	}

@Override
//调用反射机制
	protected void dealNetMessage(NetMessage message) {
		DealNetMessage.dealCommand(this, message);
	}

好了,我们通过反射机制的灵活运用,将Conversation类的***DealNetMessage 变得简单,清晰,易于之后的拓展***。

相信认真看过次博文之后,一定深有感慨,你想到了什么,可以给我说说嘛?欢迎留言!

全部评论

相关推荐

accaacc:2到4k,不是2k到4k,所以年薪是30块
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务