java rmi 传递对象,java – 如何在RMI方法中传递参数中的对象?

我试图在RMI方法中添加参数.当我添加例如字符串一切正常.但我不确定我是否可以传递我创建的对象.我是RMI的新手,所以我的代码非常简单:

HelloIF

public interface HelloIF extends Remote {

String greeting(Context c) throws RemoteException;

}

你好

public class Hello extends UnicastRemoteObject implements HelloIF {

public Hello() throws RemoteException {

}

public String greeting(Context c) throws RemoteException {

addToContext(c);

report(c);

return "greeting";

}

void addToContext(Context c) {

c.addID(Thread.currentThread().getId());

}

void report(Context c) {

System.out.println("Hello.greeting() thread : "

+ Thread.currentThread().getName() + " "

+ Thread.currentThread().getId());

System.out.println("Hello.greeting() context : "

+ c.getDistributedThreadName() + " " + c.getRequestType());

}

}

为RMIServer

public class RMIServer {

public static void main(String[] args) throws RemoteException, MalformedURLException {

LocateRegistry.createRegistry(1099);

HelloIF hello = new Hello();

Naming.rebind("server.Hello", hello);

System.out.println("server.RMI Server is ready.");

System.out.println("RMIServer.main() thread : " + Thread.currentThread().getName()

+ " " + Thread.currentThread().getId());

}

}

RMIClient

public class RMIClient {

public static void main(String[] args) throws RemoteException, MalformedURLException, NotBoundException {

Context context = new Context("request1", Thread.currentThread().getName()+System.currentTimeMillis());

Registry registry = LocateRegistry.getRegistry("localhost");

HelloIF hello = (HelloIF) registry.lookup("server.Hello");

System.out.println(hello.greeting(context));

System.out.println("RMIClient.mian() thread : " + Thread.currentThread().getName()

+ " " + Thread.currentThread().getId());

}

}

最后我的班级上下文

public class Context

{

private String requestType;

private String distributedThreadName;

private List IDList;

(...) getters/setters

}

我该怎么做才能使传递上下文成为可能?

解决方法:

您的对象应该实现Serializable.我可以看到这将是一个问题.这是必需的,因为两个部分之间的通信是使用序列化完成的,因此需要发送到其他部分的每个对象都需要是实现Serializable的类的实例.

public class Context implements Serializable

{

private String requestType;

private String distributedThreadName;

private List IDList;

(...) getters/setters

}

请添加一个serialVersionUID作为一个好习惯.就像是:

private static final long serialVersionUID = 20120731125400L;

标签:java,rmi

来源: https://codeday.me/bug/20190725/1537971.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值