由于只有 MEF 2 已移植到 .NET Core,因此我们只能访问 System.Composition 中的类型,而不能访问System.ComponentModel.Composition中的类型。因此,无法像以前使用 MEF 1 那样设置该属性。
不过,您可以为通过 API 定义的每个导出设置部件创建策略。
由于我们临近万圣节,假设我们有这些课程:
abstract class Monster { }
class It : Monster { }
class Zombie : Monster { }
class Wife : Monster { }
在 MEF 2 中,您需要创建一个 ConventionBuilder 来定义您的导出,如下所示:
var rules = new ConventionBuilder();
rules.ForTypesDerivedFrom<Monster>()
.Export<Monster>();
这里有趣的部分是默认情况下强制执行非共享创建策略,因此不需要该属性。让我们测试一下:
var config = new ContainerConfiguration()
.WithAssemblies(new[]{ typeof(Monster).GetTypeInfo().Assembly}, rules);
var container = config.CreateContainer();
var monsterA = container.GetExports<Monster>().First();
var monsterB = container.GetExports<Monster>().First();
Console.WriteLine(monsterA == monsterB);
现在,由于默认情况下我们不强制在导出中共享,这将写入控制台False。
为了强制共享,我们只需将.Shared()添加到.Export之后的方法链中,如下所示:
rules.ForTypesDerivedFrom<Monster>()
.Export<Monster>()
.Shared();
如果我们再次运行测试,我们将得到True,因为现在两个实例都指向同一个引用。
对于组成部分,你会做这样的事情:
class TerrorContainer
{
[ImportMany]
public IEnumerable<Monster> Monsters { get; set; }
}
无论你在哪里作曲,你都会写:
var terrorContainer = new TerrorContainer();
container.SatisfyImports(terrorContainer);
希望这可以帮助!