我使用以下语法创建了一个对象:
var newMessage = Activator.CreateInstance(client.Key);
它似乎创建了一个正确类型的对象并允许设置对象属性。但是,当我将对象传递给带有签名的方法时:
public void Publish<T>(T messageBody)
T 定义的 Type 是 object。
我该如何解决这个问题?我无法更改方法签名 - 它来自库 - 我需要能够在运行时创建对象而不事先知道它们的类型。
更新
我尝试执行的功能与发送(发布)消息有关。通常我会注册一个消息处理程序,例如:
RegisterHandler<MyMessage> (m => do something with message );
然后可以打电话
Publish<MyMessage> (message)
最终将在处理程序处结束。这很酷并且工作正常。
我想要做的是插入一个中介作为交换并将消息发布到多个处理程序。我知道我可以使用其他东西来为我做这件事,例如 RabbitMQ,但我希望能够通过对当前代码进行小的修改来实现它。
所以我有一个注册订阅的方法:
public virtual void registerSubscription<T1,T2>()
{
if (handlerMap.ContainsKey(typeof(T2)))
{
throw new ArgumentException("Message handler has already been registered for type: " +typeof(T2).Name);
}
if (!handlerMap.ContainsValue(typeof(T1)))
{
mqHost.RegisterHandler<T1> (m => distributeMessage(m) );
}
handlerMap[typeof(T2)] = typeof(T1);
}
我用两个类调用该方法,一个基类和一个继承基类的类:
public class MyMessage
{
public string name {get;set;}
}
public class MyMessage2:MyMessage{}
这一点效果很好,我得到了一张处理程序的地图。当我做下一点,distributeMessage 方法时,问题就来了。
var match = handlerMap.Where(i => i.Value == message.Body.GetType());
foreach (var client in match)
{
var newMessage = Activator.CreateInstance(client.Key);
newMessage.PopulateWith(message.Body);
messageProducer.Publish(createMessage(newMessage));
}
messageProducer.publish 具有签名:
public void Publish<T>(T messageBody)
我不能(轻松)修改它 - 它是图书馆的一部分。我可以调用另一种方法:
public void Publish<T>(IMessage<T> message)
但我看不出这会更容易,因为我必须创建一个仍然需要 .