Remoting方法重载遇到的一个问题

简介: 在通过Remoting调用重载的泛型方法时,遇到了一个奇怪的问题,现使用一个例子一步步来说明如下。 一.没有重载的情况      假设Remoting的接口是IComputer:     public interface IComputer    {         int Ad...

     在通过Remoting调用重载的泛型方法时,遇到了一个奇怪的问题,现使用一个例子一步步来说明如下。

一.没有重载的情况

     假设Remoting的接口是IComputer:

    public   interface  IComputer
    {
        
int  Add < TEntity > (TEntity c);       
    }

     在Remoting Server上的实现非常简单:

    public   class  Computer IComputer
    {        
        public int Add<TEntity>(TEntity c)
        {
            return 0;
        }  
        
    }

     然后,通过Spring.net分别在配置Server和Client的Remoting通道,接着Client作如下调用:

     IComputer remoteComupter  =  (IComputer)Program.SpringContext.GetObject( " remotingComputer " );
     
int  res2  =  remoteComupter.Add < GameRecordDetail > ( new  GameRecordDetail());

     这个调用是成功的,没有任何问题,返回值为0。

二.添加一个重载

     我们为IComputer接口添加一个重载方法,如下:

     public   interface  IComputer
    {
        int Add<TEntity>(TEntity c);
        int Add<TEntity>(IList<TEntity> list);
    }

     服务端对重载方法的实现仍然是直接返回0。这时在Client再次调用前面的方法,会抛出System.NullReferenceException。异常的堆栈位置是:      

 Server stack trace: 
       在 System.Runtime.Remoting.Messaging.MethodCall.ResolveMethod(Boolean bThrowIfNotResolved)
       在 System.Runtime.Remoting.Messaging.MethodCall..ctor(Object handlerObject, BinaryMethodCallMessage smuggledMsg)
       在 System.Runtime.Serialization.Formatters.Binary.BinaryMethodCall.ReadArray(Object[] callA, Object handlerObject)
       在 System.Runtime.Serialization.Formatters.Binary.ObjectReader.Deserialize(HeaderHandler handler, __BinaryParser serParser, Boolean fCheck, Boolean isCrossAppDomain, IMethodCallMessage methodCallMessage)
       在 System.Runtime.Serialization.Formatters.Binary.BinaryFormatter.Deserialize(Stream serializationStream, HeaderHandler handler, Boolean fCheck, Boolean isCrossAppDomain, IMethodCallMessage methodCallMessage)
       在 System.Runtime.Remoting.Channels.CoreChannel.DeserializeBinaryRequestMessage(String objectUri, Stream inputStream, Boolean bStrictBinding, TypeFilterLevel securityLevel)
       在 System.Runtime.Remoting.Channels.BinaryServerFormatterSink.ProcessMessage(IServerChannelSinkStack sinkStack, IMessage requestMsg, ITransportHeaders requestHeaders, Stream requestStream, IMessage
&  responseMsg, ITransportHeaders &  responseHeaders, Stream &  responseStream)
    Exception rethrown at [
0 ]: 
       在 System.Runtime.Remoting.Proxies.RealProxy.HandleReturnMessage(IMessage reqMsg, IMessage retMsg)
       在 System.Runtime.Remoting.Proxies.RealProxy.PrivateInvoke(MessageData
&  msgData, Int32 type)
       在 RemotingLib.IComputer.Add[TEntity](TEntity c)

 

三.通过修改方法名消除重载

     现将后面添加的方法重命名为Add2,Client再次调用前面的方法,一切又恢复正常。

 

四.仍然使用重载,但去掉泛型参数

     现在我们恢复重载,但将泛型参数去掉,如下所示:

    public   interface  IComputer
    {
        
int  Add(GameRecordDetail c);
        
int  Add(IList < GameRecordDetail >  list);
    }

     服务端对两个方法的实现仍然是直接返回0。Client再次调用前面的方法,一切是正常的。

 

五.测试的结果

     根据上述的试验,我们可以总结出,出现上述奇怪现象的条件有以下几点:

1.通过Remoting调用的目标方法必须是泛型的。

2.通过Remoting调用的目标方法必须有重载。

     如果满足这两个条件,那么调用目标方法时就会抛出上面的System.NullReferenceException。那么,为什么会这样了?答案探索中......

     针对这个问题,目前我暂用的解决方案是,通过重命名方法名以消除重载。 

 

目录
相关文章
|
6月前
|
Java
在Java中,多态性是通过继承和接口实现的
【4月更文挑战第7天】在Java中,多态性是通过继承和接口实现的
66 1
|
6月前
|
Java
Java一分钟之-多态性:理解重写与接口
【5月更文挑战第9天】本文介绍了Java中的多态性,主要通过方法重写和接口实现。重写允许子类根据实际类型执行不同实现,关键点包括方法签名相同、访问权限不降低以及final、static和abstract方法不可重写。接口是抽象类型,包含抽象方法,提供另一种多态性实现。常见问题包括混淆重载与重写、不理解动态绑定以及滥用接口。为避免问题,需明确重写目的、合理设计接口,并在使用多态时注意类型检查。多态性是提升代码质量和灵活性的关键。
66 1
|
5月前
|
Java
JavaSE——面向对象高级二(4/4)-接口的其他细节-三个新方法(默认方法、私有方法、静态方法),接口的多继承
JavaSE——面向对象高级二(4/4)-接口的其他细节-三个新方法(默认方法、私有方法、静态方法),接口的多继承
37 0
|
Java
Java Reflection机制 实现类的反射与动态调用
Java Reflection机制被广泛用于实现类的反射和动态调用,反射是指在运行时检查和操作类的能力。只需要一个类的名称或对象的引用,就可以获取类的信息,调用类的方法,创建对象实例等。
58 0
|
Java 关系型数据库 MySQL
C#反射(Reflection)详解及于java反射的对比
C#反射(Reflection)详解及于java反射的对比
|
Java 程序员
JavaSE/封装、继承、多态
JavaSE/封装、继承、多态
java_类向上转型以及动态绑定机制(多态)
语法:父类类型 变量名=new 子类类型();特点:编译类型看左边,运行类型看右边
54 0
|
Java
JAVA继承范型
JAVA继承范型
57 0
Java继承、封装、多态理解
Java中的继承、封装和多态知识点是学习java必备的基础知识,看似简单,真正理解起来还是有一定难度的,今天小编再次通过实例代码给大家讲解java 封装继承多态知识,感兴趣的朋友一起学习下吧。