您的位置:首页 > 其它

MEF系列五:导入延迟

2013-12-31 15:21 155 查看


Lazy Exports

During composition of a part, an import will trigger the instantiation of a part (or parts) that expose the necessary exports
required for the original requested part. For some applications delaying this instantiation – and preventing the recursive composition down the graph – may be an important factor to consider as creation a long and complex graph of objects can be expensive
and unnecessary.

This is the motivation for MEF to support what we call lazy exports. In order to use it all you need to do is to import an [System.Lazy<T>] instead
of [T] directly.
For example, consider the code snippet bellow:

public class HttpServerHealthMonitor
{
[Import]
public IMessageSender Sender { get; set; }


The code above imports states that it depends on a contract (IMessageSender) implementation. When MEF supply this dependency
it will need to also create the IMessageSender selected and recursively the dependencies that the implementation might have.

In order to turn this import to be lazy, you just need to replace it by and Lazy<IMessageSender>:

[Export]
public class HttpServerHealthMonitor
{
[Import]
public Lazy<IMessageSender> Sender { get; set; }


In this case you are opt-in for delaying this instantiation until you actually need the implementation instance. In order to
request the instance, use the property[Lazy<T>.Value].

http://mef.codeplex.com/wikipage?title=Lazy%20Exports&referringTitle=Guide
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: