我有几个不同的名单我想打电话.它们都具有相同的类格式:id,value,description,order.我没有创建一个类来返回所有众多列表,而是想使用泛型并告诉它返回什么样的列表.但是,我无法弄清楚如何填充类.
以下是我的调用代码中的两个函数示例.这应该指示列表的类型和用于获取数据的存储过程:
Public Function getTheEyeColors()
Dim glEyeColors As New GenericList
Return glEyeColors.GetALList(Of EyeColor)("GetAllEyeColors")
End Function
Public Function getTheHairColors()
Dim glHairColors As New GenericList
glHairColors.GetALList(Of HairColor)("GetAllHairColors")
End Function
Run Code Online (Sandbox Code Playgroud)
这是我试图用来构建通用列表的代码......
Public Function GetALList(Of t)(ByVal storedproc As String) As List(Of t)
Dim lstGenericList As New List(Of t)
Dim oGenericListItem As t
Dim oProviderFactory As New ProviderFactory
Dim oConnection As DbConnection
Dim oReader As System.Data.IDataReader
Dim oFactory As DbProviderFactory
Dim oFileMgt As New FileMgt
Dim oCmd As DbCommand
oFactory = oProviderFactory.GetFactory
oConnection = oProviderFactory.GetProviderConnection(oFactory)
oCmd = oConnection.CreateCommand
oCmd.CommandType = CommandType.StoredProcedure
oCmd.CommandText = storedproc
Using (oConnection)
oConnection.Open()
oReader = oCmd.ExecuteReader()
While oReader.Read
HERE IS WHERE I AM NOT SURE HOW TO POPULATE THE EYECOLOR OR HAIRCOLOR CLASS
lstGenericList.Add(oGenericListItem)
End While
oConnection.Close()
End Using
Return lstGenericList
End Function
Run Code Online (Sandbox Code Playgroud)
您可以添加两个通用约束; 我不知道如何在VB中表达它们,但这里是C#版本:
T : new() - 必须有一个无参数的构造函数T : ICommonInterface- T必须实现一个接口然后,将公共属性(ID,Value,Description,Order)放入接口,您将能够创建一个new T(),设置属性并将其添加到列表中.
编辑:
VB语法指定它必须是可创建的并实现接口是:
(Of T As {ICommonInterface, New})