我认为这是不可能的,但这里...
我想添加可以处理 n 个泛型的方法。例如 :
bool<T> MyMethod() where T: Isomething
{
}
适用于一种类型
bool<T,K> MyMethod() where T: Isomething
{
}
适用于两种类型
有没有一种方法可以处理 n 种类型 - 例如
bool<T[]> MyMethod() where T: Isomething
{
}
我想要这样做的原因是实现一种静态 nhibernate 辅助方法,该方法可以从多个程序集加载 - 现在它对于一个程序集非常有效。我目前的方法如下图:
public static ISessionFactory GetMySqlSessionFactory<T>(string connectionString, bool BuildSchema)
{
//configuring is meant to be costly so just do it once for each db and store statically
if (!AllFactories.ContainsKey(connectionString))
{
var configuration =
Fluently.Configure()
.Database(MySQLConfiguration.Standard
.ConnectionString(connectionString)
.ShowSql() //for development/debug only..
.UseOuterJoin()
.QuerySubstitutions("true 1, false 0, yes 'Y', no 'N'"))
.Mappings(m =>
{
m.FluentMappings.AddFromAssemblyOf<T>();
m.AutoMappings.Add(AutoMap.AssemblyOf<T>().Conventions.Add<CascadeAll>);
})
.ExposeConfiguration(cfg =>
{
new SchemaExport(cfg)
.Create(BuildSchema, BuildSchema);
});
AllFactories[connectionString] = configuration.BuildSessionFactory();
}
return AllFactories[connectionString];
}
其中行:m.FluentMappings.AddFromAssemblyOf(),我想添加多种类型,例如
foreach(T in T[]){
m.FluentMappings.AddFromAssemblyOf<T>()
}
显然这是行不通的,我并不完全愚蠢,但我对仿制药不太热衷 - 有人可以确认这是不可能的:-) ..?您认为实现这种效果的最优雅的方式是什么?