RMI:java远程调用接口,比如,你在一台电脑要调用另外一台电脑的java对象,那就用RMI很方便,就像调用本机对象一样(几乎)
RPC:java远程方法调用,基本同上,就是RMI是java对象之间的调用,RPC可以不同语言。
因为你继承了一个序列化接口,这个接口需要实现一个序列号,用于唯一标识这个类。为了不出现警告,需要在类里面声明这样一个字段。
private static final long serialVersionUID = xxxxxxL;其中xxxx表示一个long的整数。
这个是为了标识当前的版本。主要用于用于远程调用。RMI这类的场景
你想,你有一个类。
public class A{
public void say(){
System.out.println("Java");
}
}
然后有一个人使用了你这个类。
但是有一天你将这个修改了。
如
public class A{
public void say(){
System.out.println("PHP");
}
}
那么调用的那个人调用A的 say方法就得不到“Java”了。而且它也不知道你有做过修改。
但是如果一开始就加上serialVersionUID 的话,那么第二次调用的时候 就可以通过判断serialVersionUID 是否发生修改从而重新获取最新的类。
简单来说,你可以把这个当成是这个类的 最后修改时间。
每一次修改这个类都应该更新这个字段。