对于类型Loan,Client和Book,我有三种类似的方法。我是一名编程学生,我想知道是否可以传入与这3个类匹配的泛型类型的参数,我的意思是在括号之间传递不同的类型,如<T>
,对于这三个类只有一种方法。我试过了,<object>
但是没有用。
public void LoadStoreLoans(ObservableCollection<Loan> loansCollection)
{
IList<Loan> loans = db.Query<Loan>(); //db4o
loansCollection = loans != null ? new ObservableCollection<Loan>(loans) : new ObservableCollection<Loan>();
}
谢谢。
是的,如果您总是替换它,我建议使该集合成为返回值(这不是可观察的集合的目的):
public ObservableCollection<T> LoadStoreCollection<T>()
{
IList<T> queried = db.Query<T>();
return queried != null ? new ObservableCollection<T>(queried) : new ObservableCollection<T>();
}
对于对象的第一次尝试:我从未使用过db4o,但我认为它在函数中使用给定的类型参数(Load
或T
)Query
来推断要查询的表。给定会object
产生错误,因为没有的表格object
。您需要指定替代类型或更好的替代类型-泛型类型参数-在执行过程中将其绑定到实际类型。当使用调用时T = Loan
,该db.Query
调用可以查询Loan
表,就像您首先要写db.Query<Loan>
的一样。
由于集合是问题中的一个参数,因此您可能会认为您会多次调用同一函数T
,但是:始终使用new
禁用可观察集合可以提供的所有好处来重新初始化同一可观察集合变量,例如,您永远不会收到一个更改了集合的事件(因为您监听替换后的集合),则无法将其绑定到控件,如果将其他对象注册到该事件,则会引入一个内存漏洞:)
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句