程序想实现的效果:客户端现在有一个对象“狗”,加入了一个LinkedList集合,随后将该集合发送到服务器端。服务器端接收到这个集合,会调用一个方法Judge来判断LinkedList里面有什么,如果是狗则调用XXX方法,如果是猫则调用XXX方法。
问题描述:现在客户端与服务器端单独抽出成为一个jar工具包。也就是说服务器端和客户端会预先写好。换而言之,在该包里没有Judge方法,Judge方法是在程序实际编写时再写成的。那么此时服务器端代码应该怎么写?
实际应用举例:当实际使用时,应用程序(客户端)调用Send(),此时该jar包中已编好的程序会将对象发送到服务器端;在服务器端只需写一个Judge(),该方法会被jar包中的程序自动调用。
大体实现的代码:
客户端:
//向服务器发送数据
public void send(TransferLinkedList linkedList) throws IOException{
/**
* 本方法用于客户端向服务器发送数据。首先从套接字中获取基本输出流,接下来将该输出流转换为对象输出流以输出对象
*/
//从该套接字中获取输出流
OutputStream clientOut = client.getOutputStream();
//将该输出流处理为对象输出流
ObjectOutputStream clientOutObject = new ObjectOutputStream(clientOut);
//传输信息
clientOutObject.writeObject(linkedList);
//刷新缓存区
clientOutObject.flush();
//接收服务器信息以确认是否成功发送信息
}
服务器端:
//开始运行
public void run() throws IOException{
//服务器一直等待客户端的连接,当与客户端建立连接时,服务器分出一个线程建立新的Socket进行处理,原有Socket继续等待
//此处为了简便省略线程
while(true){
Socket socket = server.accept();
//处理新的Socket
/**
* 调用Judge方法,Judge方法应在实际使用该jar包时编写
* 此时不知道Judge包含哪些方法,是怎么样的路径,甚至名字是否是Judge
* 该使用什么方法来处理?反射?工厂模式?感觉都不大能解决
*/
}
}
你这个问题实际上就是要定义一个远程调用协议
1.在客户段给发送信息前面加一个头,例如:
@header@type:methodinvoke@服务端的类@服务端的方法@参数列表@end@header@
2.在服务端接受客户段信息时,判断一下头部是否有如上头,如果有,按照协议解析,
然后根据解析内容通过反射调用客户段请求的逻辑执行
此外,服务端最好使用线程池处理客户段请求
在类中定义线程池常量private static ExecutorService executoService;
在调用具体逻辑时
executoService = Executors.newFixedThreadPool(Runtime.getRuntime().availableProcessors() * 10);
executoService.execute(new SocketThread(socket));
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。